Compare commits

..

1431 Commits

Author SHA1 Message Date
Benjamin Canac
83c2b70d98 chore(release): v3.0.0-alpha.10 2024-12-09 11:11:40 +01:00
Benjamin Canac
3b9ca2263d fix(CommandPalette): keep ignoreFilter groups at their place (#2833) 2024-12-09 10:17:54 +01:00
renovate[bot]
6636543256 chore(deps): update all non-major dependencies (v3) (#2848)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-12-09 10:17:25 +01:00
Malik-Jouda
f98b91c22a fix(ColorPicker): handle RTL mode (#2858) 2024-12-09 10:17:05 +01:00
Benjamin Canac
857238ff14 chore(deps): update reka-ui 2024-12-08 11:02:40 +01:00
Christophe Carvalho Vilas-Boas
8b5d412fd7 feat(locale): add Portuguese language (#2855) 2024-12-07 01:09:00 +01:00
renovate[bot]
ed44d9d101 chore(deps): update devdependency @nuxt/test-utils to ^3.15.1 (v3) (#2839)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-12-07 01:08:21 +01:00
renovate[bot]
5a900e460b chore(deps): update tailwindcss to v4.0.0-beta.6 (v3) (#2853)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-12-07 00:55:35 +01:00
Christophe Carvalho Vilas-Boas
4b241ba3c3 fix(types): handle array of strings in AppConfig (#2854) 2024-12-07 00:55:11 +01:00
Benjamin Canac
80befc107c fix(defineShortcuts): return useEventListener to unregister the listener
Resolves #2031
2024-12-06 23:37:22 +01:00
Benjamin Canac
6c946dc0e7 docs(deps): update @nuxt/ui-pro 2024-12-06 17:39:13 +01:00
Benjamin Canac
2d81c02356 docs(Header): use Drawer as menu 2024-12-06 17:20:21 +01:00
Benjamin Canac
d3b3b9bef3 docs(installation): add app section 2024-12-06 17:20:21 +01:00
Benjamin Canac
b7ba2c7759 fix(Modal): prevent from going out of screen
Resolves #2711
2024-12-06 17:20:21 +01:00
Malik-Jouda
198d04de51 fix(Stepper): handle RTL mode (#2844) 2024-12-06 15:08:39 +01:00
renovate[bot]
16e0339e7a chore(deps): update all non-major dependencies (v3) (#2820)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-12-06 11:18:34 +01:00
Benjamin Canac
6f1f9f4d81 docs(app): update module & framework select 2024-12-05 23:36:02 +01:00
Benjamin Canac
46f4e5a24d docs(app): redirect when module changes
Resolves #2840
2024-12-05 23:26:44 +01:00
Benjamin Canac
b983ea2aec docs(app): hide github link on mobile 2024-12-05 19:13:26 +01:00
Benjamin Canac
bd4abfa880 docs(app): improve module select padding 2024-12-05 19:12:01 +01:00
Benjamin Canac
c1ff978370 fix(Tabs): truncate not working 2024-12-05 19:11:51 +01:00
Benjamin Canac
984bb0899c docs(app): use tabs to switch framework & module (#2837) 2024-12-05 19:01:40 +01:00
Benjamin Canac
a938d24f90 fix(Tabs): prevent hover on disabled 2024-12-05 18:15:03 +01:00
Benjamin Canac
0f8c398673 docs: handle @nuxt/ui-pro components display 2024-12-05 16:43:12 +01:00
Benjamin Canac
695224f91f chore(ContextMenu/DropdownMenu/NavigationMenu): consistent trailing slot 2024-12-05 16:29:28 +01:00
Benjamin Canac
4b653ef773 feat(NavigationMenu): handle item.trailingIcon display 2024-12-05 16:29:28 +01:00
Benjamin Canac
816bb69deb fix(Stepper): missing import 2024-12-05 15:22:25 +01:00
Benjamin Canac
5a7c3b13d3 docs(SupportedLanguages): improve emojis 2024-12-05 15:16:41 +01:00
Benjamin Canac
b741ef3313 feat(Avatar): add default slot for fallback 2024-12-05 15:16:28 +01:00
Benjamin Canac
bc80a0121f chore(ColorPicker): use reka-ui 2024-12-05 14:47:48 +01:00
Alex
e475b6438d feat(ColorPicker): implement component (#2670)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-12-05 14:11:43 +01:00
Benjamin Canac
3e283117d2 docs(app): missing target _blank on links 2024-12-05 12:21:50 +01:00
Romain Hamel
6484d010a1 feat(Stepper): new component (#2733)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-12-05 12:20:45 +01:00
renovate[bot]
d539109357 chore(deps): update tailwindcss to v4.0.0-beta.5 (v3) (#2791)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-12-04 21:32:35 +01:00
Benjamin Canac
01c3934403 docs: add @nuxt/ui-pro source (#2775) 2024-12-04 21:15:07 +01:00
Benjamin Canac
e79103131f chore(deps): dedupe 2024-12-04 14:46:24 +01:00
Benjamin Canac
37f05e2ba8 docs(deps): update @nuxt/ui-pro 2024-12-03 16:43:39 +01:00
Benjamin Canac
81ac076219 feat(module)!: migrate to reka-ui (#2448) 2024-12-03 16:11:32 +01:00
phbe
c440c91a29 fix(locale): improve German translation (#2826) 2024-12-03 16:06:18 +01:00
sam
b7ff7d8aa6 feat(locale): add Brazilian Portuguese language (#2825) 2024-12-03 13:53:25 +01:00
Jakub Jelínek
68a10f09d5 feat(locale): add Slovak language (#2821) 2024-12-02 17:38:11 +01:00
Christian López C
004a577467 feat(Table): handle meta.class on th and td (#2790)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-12-02 13:43:08 +01:00
renovate[bot]
f712135576 chore(deps): lock file maintenance (v3) (#2818)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-12-02 11:24:16 +01:00
Benjamin Canac
e2aaf5ba21 chore(renovate): ignore typescript 2024-12-02 11:05:26 +01:00
renovate[bot]
d65c7376d9 chore(deps): update all non-major dependencies (v3) (#2754)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-12-02 11:03:49 +01:00
Benjamin Canac
f04c2082ad docs(Header): move dropdown out of link 2024-11-30 11:48:13 +01:00
Benjamin Canac
bda6098db3 docs(app): improve navigation 2024-11-29 17:28:19 +01:00
Benjamin Canac
8344d852a5 docs(deps): update @nuxt/content & @nuxt/ui-pro 2024-11-29 17:28:10 +01:00
Benjamin Canac
6bd8a06871 docs(Header): replace badge by dropdown 2024-11-29 16:46:20 +01:00
Benjamin Canac
148b02464d fix(components): specify collisionPadding to all menus 2024-11-29 16:39:35 +01:00
Benjamin Canac
1240a3b604 docs(deps): update @nuxt/content 2024-11-29 16:15:49 +01:00
Benjamin Canac
e3b8d0e60e docs(deps): update @nuxt/content 2024-11-29 16:01:33 +01:00
Benjamin Canac
0d41210c91 docs: improve callout links 2024-11-29 12:41:31 +01:00
Guillaume Chau
bc2bcb30d9 fix(icons): make loading icon clockwise (#2797)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-28 15:18:14 +01:00
Aaron Dewes
ed2722257a fix(ContextMenu): remove close animation (#2798) 2024-11-28 14:56:18 +01:00
Romain Hamel
f06fbafc1e fix(devtools): error with renderer when colorMode is disabled (#2792) 2024-11-28 10:51:55 +01:00
Kotering
ecc4755a17 feat(locale): add Japanese language (#2794) 2024-11-28 10:25:37 +01:00
Benjamin Canac
9b58ce05f0 chore(icons): sort 2024-11-27 20:22:45 +01:00
Sébastien Chopin
a481410c5f docs(installation):add UI template instructions 2024-11-27 16:36:57 +01:00
Benjamin Canac
cd7ab3b2b9 docs(theme): fix framework-only usage 2024-11-27 15:55:30 +01:00
Benjamin Canac
9a17f90985 docs(app): hide links slot 2024-11-27 15:17:27 +01:00
Alex
3496b2d541 docs(content): consistent callouts links style (#2786) 2024-11-27 14:28:19 +01:00
Sandro Circi
a6c22052e1 fix(Link): partial query match for Vue (#2787) 2024-11-27 14:27:47 +01:00
Benjamin Canac
6eb0bbbe1b docs(app): update error 2024-11-27 12:39:51 +01:00
Benjamin Canac
a2512f680d feat(css): use color-scheme utilities on body 2024-11-27 12:37:29 +01:00
Benjamin Canac
4eb79021ed chore(renovate): update
Co-Authored-By: Sébastien Chopin <seb@nuxt.com>
2024-11-27 12:37:01 +01:00
renovate[bot]
8a45c25df3 chore(deps): update vueuse monorepo to v12 (v3) (major) (#2784)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-27 12:11:58 +01:00
Dafitra
004fa1ebcb refactor(App): remove default locale handling (#2760) 2024-11-27 10:35:12 +01:00
Malik-Jouda
0f648024e0 feat(Calendar): add icon props (#2778) 2024-11-26 18:31:25 +01:00
Benjamin Canac
e7995e7a0b docs(app): improve framework hydration (#2780)
Co-authored-by: Sébastien Chopin <seb@nuxt.com>
2024-11-26 18:23:26 +01:00
Alex
15ca2f5701 docs(ComponentCode): add cast prop (#2773) 2024-11-26 16:13:47 +01:00
Benjamin Canac
08b9e4bff0 chore(README): update 2024-11-26 15:18:21 +01:00
Benjamin Canac
f49b49fd2c docs(app): update header github link 2024-11-26 15:10:17 +01:00
Benjamin Canac
a74e8c4444 docs(robots): update 2024-11-26 15:10:08 +01:00
Benjamin Canac
781081132d chore(README): update github links 2024-11-26 15:10:00 +01:00
Malik-Jouda
b1550d58ad fix(Table): handle loading animation in RTL mode (#2771) 2024-11-26 14:45:03 +01:00
Malik-Jouda
e7b69b7d6f fix(Calendar): handle icons in RTL mode (#2770) 2024-11-26 13:17:06 +01:00
Benjamin Canac
9478fc0768 fix(Calendar): omit as / asChild props 2024-11-26 13:12:11 +01:00
Alex
2e9aeb5f05 feat(Calendar): implement component (#2618)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-26 12:24:20 +01:00
Benjamin Canac
86f2b4856c fix(NavigationMenu): wrong badge class
Resolves #2766
2024-11-26 12:23:01 +01:00
Benjamin Canac
ba874c9191 docs(app): framework select global (#2719)
Co-authored-by: harlan <harlan@harlanzw.com>
2024-11-25 15:47:52 +01:00
Benjamin Canac
ffc81cc950 chore(CommandPalette): pass active to children 2024-11-25 14:39:15 +01:00
Benjamin Canac
d783387ed3 test(CommandPalette): improve 2024-11-25 14:26:58 +01:00
Benjamin Canac
37655377e9 feat(CommandPalette): add active field on items for consistency 2024-11-25 14:22:39 +01:00
renovate[bot]
7ab88d30b2 chore(deps): lock file maintenance (v3) (#2752)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-25 12:48:44 +01:00
renovate[bot]
ccb79b7ee4 chore(deps): update all non-major dependencies (v3) (#2705)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-25 12:37:53 +01:00
kyyy
c9806da6d8 fix(Form)!: resolve async validation in yup & issue directly mutate state (#2702)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-23 19:30:20 +01:00
Dafitra
3bccb6782a fix(useLocale): update locale import to enable tree shaking (#2735) 2024-11-22 23:03:44 +01:00
renovate[bot]
5a01a81577 chore(deps): update tailwindcss to v4.0.0-beta.2 (v3) (#2736)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-22 23:03:00 +01:00
Arcitezz
3baddfd121 feat(i18n): add Dutch locale (#2728) 2024-11-22 12:44:27 +01:00
Benjamin Canac
a7a1227c93 fix(Breadcrumb): missing aria-hidden on presentation items
Resolves #2725
2024-11-22 09:53:26 +01:00
Benjamin Canac
b259ddf271 docs(app): update @source usage 2024-11-21 23:41:29 +01:00
Benjamin Canac
c47ffc1cd5 docs: update links to tailwind v4 beta docs 2024-11-21 23:23:45 +01:00
Malik-Jouda
0baa3a06d4 fix(Progress): handle horizontal animation in RTL mode (#2723) 2024-11-21 23:07:59 +01:00
renovate[bot]
b140dbfe63 chore(deps): update tailwindcss to v4.0.0-beta.1 (v3) (#2721)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-21 22:32:52 +01:00
Benjamin Canac
6d917baac0 chore(css): update reset styles
https://github.com/tailwindlabs/tailwindcss/pull/15064
2024-11-21 22:31:37 +01:00
renovate[bot]
c511c95537 chore(deps): update tailwindcss to v4.0.0-alpha.36 (v3) (#2718)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Sandro Circi <sandro.circi@digitoolmedia.com>
2024-11-21 22:18:50 +01:00
Hasan Mumin
de8228e504 feat(i18n): add Turkish locale (#2716) 2024-11-21 17:27:41 +01:00
Benjamin Canac
29d2acf564 docs(getting-started): update faq 2024-11-21 16:51:28 +01:00
Benjamin Canac
f5452ba0c5 docs(icon): add missing props 2024-11-21 15:54:36 +01:00
Alex
b6a841e975 docs(i18n): display supported languages in a cards (#2709) 2024-11-21 11:21:35 +01:00
renovate[bot]
7bf85e9a09 chore(deps): update tailwindcss to v4.0.0-alpha.35 (v3) (#2707)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-21 10:56:00 +01:00
Benjamin Canac
9e8d50b2b8 chore(deps): dedupe 2024-11-20 18:54:15 +01:00
Benjamin Canac
b13b9e3ec0 docs(deps): update @nuxt/content to 3.0.0-alpha.7 2024-11-20 18:53:53 +01:00
Benjamin Canac
126c893635 docs(deps): update @nuxt/ui-pro 2024-11-20 17:56:34 +01:00
Farnabaz
7d8b721bdd docs(deps): update @nuxt/content (#2706) 2024-11-20 13:44:37 +01:00
renovate[bot]
b120e8d998 chore(deps): update all non-major dependencies (v3) (#2694)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-20 10:21:21 +01:00
renovate[bot]
2c4634a58f chore(deps): update nuxt framework to ^3.14.1592 (v3) (#2700)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-20 10:20:55 +01:00
Dewdew
2cbf83eb84 feat(locale): translate Korean (#2703)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-20 09:58:52 +01:00
Benjamin Canac
da1b0bac04 docs(dropdown-menu/context-menu): move class to ui.content
After a6ecef0f fix
2024-11-20 09:51:19 +01:00
Benjamin Canac
7cc51d2efa test: update snapshots 2024-11-20 09:35:04 +01:00
Benjamin Canac
c163ed8187 docs: improve titles 2024-11-19 22:52:23 +01:00
Benjamin Canac
a6ecef0f0d fix(components): apply class on trigger instead of content when present
Resolves #2132
2024-11-19 22:10:27 +01:00
Benjamin Canac
faec8260a4 test(Popover/Tooltip): add class / ui props 2024-11-19 22:09:33 +01:00
Malik-Jouda
7a02bfeba6 playground: improve responsive (#2675) 2024-11-19 19:26:09 +01:00
Benjamin Canac
9dd525ca26 docs(deps): update @nuxt/content to alpha.6 (#2692) 2024-11-19 18:41:04 +01:00
Benjamin Canac
21d8c352a9 chore(release): v3.0.0-alpha.9 2024-11-19 16:03:52 +01:00
Benjamin Canac
5deadc7096 Revert "docs(ComponentCode/ComponentExample): use relative imports"
This reverts commit d75f47419d.
2024-11-19 15:54:51 +01:00
Benjamin Canac
fa9f0a7e2a chore(Toaster): use ToastPortal from radix-vue 2024-11-19 15:41:26 +01:00
Alex
143c015bbd docs(i18n): display supported languages in a table (#2684)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-19 15:33:01 +01:00
Benjamin Canac
d75f47419d docs(ComponentCode/ComponentExample): use relative imports 2024-11-19 15:18:06 +01:00
Alex
7b148daf1f cli: fix line break doc template (#2687) 2024-11-19 14:06:48 +01:00
Benjamin Canac
30e0c7fddd docs(deps): update @nuxt/ui-pro 2024-11-19 12:24:40 +01:00
Mohet
14fb21be00 feat(locale): add Persian language (#2682)
Co-authored-by: Ali Zemani <ali.ze@arianatech.ir>
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-19 12:10:09 +01:00
renovate[bot]
25091bad48 chore(deps): lock file maintenance (v3) (#2672)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-19 11:59:54 +01:00
renovate[bot]
b75ed29068 chore(deps): update all non-major dependencies (v3) (#2679)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-19 11:40:06 +01:00
Thomas
b2fa65734b fix(css): --font-family-sans renamed to --font-sans (#2680)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-19 10:07:01 +01:00
Dewdew
d3a079a644 fix(Textarea): autoresize does not work when initializing modelValue (#2681) 2024-11-19 10:02:19 +01:00
renovate[bot]
8c6a8c283f chore(deps): update all non-major dependencies (v3) (#2642)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-18 23:18:35 +01:00
kicaj
2fc36c878c feat(locale): add Polish language (#2678) 2024-11-18 22:49:05 +01:00
Aaron Dewes
992be91823 fix(locale): Improve German translation (#2676) 2024-11-18 21:59:27 +01:00
Alex
bd2f077fe8 feat(InputNumber): implement component (#2577)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-18 10:08:57 +01:00
Sandro Circi
7329900ae5 feat(Link): allow partial query match for its active state (#2664)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-17 12:16:19 +01:00
Benjamin Canac
8d85498ee1 fix(Button): improve neutral solid variant hover 2024-11-16 21:59:27 +01:00
Benjamin Canac
5c292cf620 chore(Alert/Toast): improve tsdoc 2024-11-16 14:27:16 +01:00
Benjamin Canac
c0837059a9 playground: add color mode button 2024-11-15 12:58:06 +01:00
Benjamin Canac
f5ea2411dc chore(package): add dev:vue script 2024-11-15 12:57:55 +01:00
Malik-Jouda
1fbbfe8df0 fix(Carousel): use dir from locale (#2647) 2024-11-15 12:00:51 +01:00
Sandro Circi
0daac5bafb fix(Toast): unreachable behind overlays (#2650)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-15 11:59:08 +01:00
Benjamin Canac
756f791a1a fix(Breadcrumb): render as nav
Resolves #2649
2024-11-15 09:52:44 +01:00
Eduard Aymerich
8ed434c105 feat(locale): translate Spanish (#2644) 2024-11-15 09:48:11 +01:00
renovate[bot]
190a2c9799 chore(deps): update tailwindcss to v4.0.0-alpha.34 (v3) (#2645)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-15 09:47:16 +01:00
Alex
e55c0e2594 feat(locale): typing dir (#2643) 2024-11-14 19:53:35 +01:00
Benjamin Canac
4312ca4702 docs(deps): update @nuxt/ui-pro 2024-11-14 18:26:50 +01:00
renovate[bot]
2289742656 chore(deps): update dependency @nuxt/icon to ^1.7.5 (v3) (#2639)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-14 16:45:20 +01:00
Benjamin Canac
601f4b2cd2 fix(PinInput): missing useFormField import 2024-11-14 15:57:21 +01:00
Benjamin Canac
cd080541a0 docs(deps): add @iconify-json/logos 2024-11-14 15:45:22 +01:00
Benjamin Canac
5722e0802d playground(deps): add @iconify-json/simple-icons 2024-11-14 15:44:35 +01:00
Benjamin Canac
8d0026558a fix(css): remove useless spacing override 2024-11-14 11:47:58 +01:00
Malik-Jouda
e5119a9ca4 fix(Breadcrumb/Carousel/Pagination): handle icons in RTL mode (#2633) 2024-11-14 10:17:55 +01:00
renovate[bot]
976dd2a386 chore(deps): update all non-major dependencies (v3) (#2629)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-14 10:16:27 +01:00
Benjamin Canac
1d95eb7246 docs(input): add more examples 2024-11-13 16:58:21 +01:00
Benjamin Canac
7cc26d098d fix(App): remove dir prop (#2630) 2024-11-13 16:23:08 +01:00
Guillaume Chau
9241ba1230 fix(FormField): missing conditions to apply container classes (#2631)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-13 15:57:35 +01:00
Daniel Roe
3396d5cebe ci: run vite build to test playground (#2624) 2024-11-13 12:22:46 +01:00
Alex
937585cb3f feat(locale): provide dir on defineLocale (#2620)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-13 12:19:21 +01:00
renovate[bot]
9c00f7c7b7 chore(deps): update all non-major dependencies (v3) (#2626)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-13 11:58:02 +01:00
Sandro Circi
73e25ed235 fix(locale): it translation (#2623) 2024-11-12 21:25:25 +01:00
kyyy
75c5e87724 feat(Form): apply transformations (#2550)
Co-authored-by: Romain Hamel <rom.hml@gmail.com>
2024-11-12 16:43:40 +01:00
max
95aa6f68b3 feat(PinInput): implement component (#2570)
Co-authored-by: Max Steinwand <msteinwand@kues.de>
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
Co-authored-by: Romain Hamel <rom.hml@gmail.com>
2024-11-12 16:11:06 +01:00
Inesh Bose
f516d7b36d feat(InputMenu/SelectMenu): add create-item prop (#2472)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-12 15:28:18 +01:00
renovate[bot]
300ccc4885 chore(deps): update all non-major dependencies (v3) (#2605)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-12 14:29:28 +01:00
Alex
e48b416e3b cli: add doc template (#2616)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-12 14:19:32 +01:00
Romain Hamel
17170bb998 playground(form): update examples (#2613) 2024-11-12 13:57:04 +01:00
renovate[bot]
fa5a3752c9 chore(deps): update tailwindcss to v4.0.0-alpha.33 (v3) (#2493)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-12 13:56:31 +01:00
Benjamin Canac
fc9711223b chore(github): update issue templates 2024-11-12 13:11:42 +01:00
Alex
8a8b1ee2e1 feat(locale): provide code (#2611) 2024-11-12 12:57:40 +01:00
Benjamin Canac
30218f1b5b feat(NavigationMenu): control items open & defaultOpen on vertical
Resolves #2608
2024-11-12 11:12:19 +01:00
Romain Hamel
3584a3328b fix(Form): match error-pattern on input validation (#2606) 2024-11-11 22:50:22 +01:00
renovate[bot]
6d3dbdbee5 chore(deps): update all non-major dependencies (v3) (#2598)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-11 21:07:54 +01:00
renovate[bot]
c614a0aafc chore(deps): lock file maintenance (v3) (#2596)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-11 19:26:57 +01:00
Sandro Circi
df7a61a97a fix(useLocale): missing import in various components (#2603) 2024-11-11 19:24:33 +01:00
Romain Hamel
143612ec73 feat(FormField): add error-pattern prop (#2601) 2024-11-11 18:35:27 +01:00
Benjamin Canac
18931acdb3 fix(InputMenu/SelectMenu): init filter with labelKey 2024-11-11 00:28:43 +01:00
Benjamin Canac
bbc6bf2455 docs(input-menu/select-menu): add countries picker examples 2024-11-11 00:08:16 +01:00
Benjamin Canac
ff1e0798d3 feat(SelectMenu): use UInput in search to handle props like icon
Resolves #2021
2024-11-10 23:22:44 +01:00
Benjamin Canac
b0be26d67f fix(Toaster): teleport to body
Resolves #2404
2024-11-10 19:21:50 +01:00
Benjamin Canac
36ea3e4045 chore(scripts): remove 2024-11-10 18:36:52 +01:00
Adam Kasper
4889d30b44 feat(locale): add support for Czech translation (#2593) 2024-11-10 18:17:32 +01:00
Benjamin Canac
944a7e0f07 Revert "fix(module): resolve #build/app.config import for vue and nuxt"
This reverts commit d6943e39c0.
2024-11-10 17:25:33 +01:00
Benjamin Canac
d6943e39c0 fix(module): resolve #build/app.config import for vue and nuxt
Resolves #2560
2024-11-10 16:45:46 +01:00
Benjamin Canac
ddb46905e7 fix(App): missing vue imports 2024-11-10 16:44:09 +01:00
renovate[bot]
0e74dbebce chore(deps): update all non-major dependencies (v3) (#2579)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-10 14:45:10 +01:00
Benjamin Canac
9e2cc5b125 fix(Modal/Slideover): prevent esc with prevent-close prop
Resolves #2501
2024-11-10 10:19:47 +01:00
Benjamin Canac
ea97759c2c feat(Popover): add prevent-close prop
Resolves #2245
2024-11-10 10:18:08 +01:00
Dewdew
95a0bbc581 fix(Link): missing relative import (#2588)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-10 10:05:17 +01:00
Benjamin Canac
ecd63ad8d6 test: update vue snapshots 2024-11-10 09:42:11 +01:00
Benjamin Canac
47f58f52ef fix(ContextMenu/DropdownMenu): relative imports with prefix 2024-11-10 09:39:37 +01:00
Benjamin Canac
446f9c1085 feat(Table): add caption prop 2024-11-09 23:55:26 +01:00
Benjamin Canac
7e8a1dd496 chore(readme): update 2024-11-09 22:06:55 +01:00
Benjamin Canac
89ee31b7ae chore(readme): update 2024-11-09 22:03:56 +01:00
Benjamin Canac
95be76940c docs(getting-started): use ::steps and mention css files 2024-11-09 22:03:49 +01:00
Benjamin Canac
761afaf40d docs(deps): update @nuxt/ui-pro 2024-11-09 21:50:20 +01:00
Sandro Circi
d167c9b807 fix(locale): Italian translation (#2584) 2024-11-09 16:15:43 +01:00
Alex
824ba56291 feat(cli): add locale command (#2586) 2024-11-09 16:14:29 +01:00
Sandro Circi
4fbbb25f68 feat(locale): add support for Italian (#2583) 2024-11-09 13:50:03 +01:00
Muhammad Mahmoud
602a667343 feat(locale): add support for Arabic (#2582) 2024-11-09 13:49:50 +01:00
BlackWhite
febda5c2b6 feat(locale): translate chinese (#2580) 2024-11-09 10:40:42 +01:00
Malik-Jouda
20379f51cc docs(nuxt.config): cannot use import.meta outside a module (#2578) 2024-11-09 10:06:56 +01:00
renovate[bot]
1ec56f3326 chore(deps): update all non-major dependencies (v3) (#2572)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-08 18:03:14 +01:00
Alex
1f44d58b64 docs(i18n): auto generated lang support (#2574)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-08 17:48:42 +01:00
Benjamin Canac
5392f988b8 docs(app): fetch files lazy on client 2024-11-08 17:35:42 +01:00
Alex
26362408b1 feat(module): support i18n in components (#2553)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-08 17:22:57 +01:00
renovate[bot]
1e7638bd03 chore(deps): update all non-major dependencies (v3) (#2563)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-08 16:55:39 +01:00
Romain Hamel
afe40033b0 fix(module): skip devtools renderer page injection if router integration is disabled (#2571) 2024-11-08 16:27:25 +01:00
Benjamin Canac
503f701c7e fix(InputMenu/SelectMenu): multiple not working with generic boolean casting
Resolves #2541
2024-11-08 10:59:13 +01:00
Benjamin Canac
d9822db6e8 chore(InputMenu/Select/SelectMenu): consistent types 2024-11-08 10:27:05 +01:00
Benjamin Canac
0ceafe1d54 fix(InputMenu/SelectMenu): look in items only with value-attribute
Resolves #2464
2024-11-08 10:26:44 +01:00
Benjamin Canac
f943f88fcc fix(InputMenu/SelectMenu): use isEqual from ohash 2024-11-08 10:19:02 +01:00
Benjamin Canac
e831813aa3 chore(git): ignore vue playground files 2024-11-07 22:35:50 +01:00
Benjamin Canac
37a359701f fix(module): remove fast-deep-equal in favor of custom isEqual 2024-11-07 21:56:56 +01:00
Benjamin Canac
557e0c92a4 docs(deps): revert @nuxt/content to 3.0.0-alpha.5 2024-11-07 21:54:42 +01:00
Benjamin Canac
7f6db45f1e feat(css): add --ui-bg-muted / --ui-border-muted variables
Those are used in Nuxt UI Pro
2024-11-07 21:43:49 +01:00
Benjamin Canac
a64a7104c5 docs(app): update links 2024-11-07 17:46:44 +01:00
Benjamin Canac
40fc8f3718 docs(app): remove icons from breadcrumb 2024-11-07 16:33:19 +01:00
Benjamin Canac
8059d540e3 docs(app): improve links 2024-11-07 16:25:01 +01:00
Benjamin Canac
42fce998e4 docs: remove markdown from descriptions 2024-11-07 15:21:38 +01:00
Benjamin Canac
70fcc68ee2 chore(release): v3.0.0-alpha.8 2024-11-07 14:58:47 +01:00
Benjamin Canac
230cda129b docs(getting-started): update 2024-11-07 14:56:31 +01:00
Benjamin Canac
1c01db4d20 docs(avatar): update 2024-11-07 14:56:00 +01:00
Benjamin Canac
c9adf333be feat(Avatar): infer width / height on <img> based on size prop 2024-11-07 14:49:39 +01:00
Benjamin Canac
ffb551ab54 test: add silent: true in vue config 2024-11-07 13:08:12 +01:00
Benjamin Canac
f1a14dd87c feat(Avatar): use NuxtImg component when available
Resolves nuxt/ui#2078
2024-11-07 13:01:52 +01:00
renovate[bot]
0454124b3c chore(deps): update dependency @iconify-json/lucide to ^1.2.12 (v3) (#2556)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-07 12:43:35 +01:00
Benjamin Canac
0bfe2b60b3 fix(module): add fast-deep-equal in optimizeDeps 2024-11-07 12:19:41 +01:00
Benjamin Canac
5ec756d263 playground(deps): add @iconify-json/lucide 2024-11-07 11:52:59 +01:00
renovate[bot]
d6a434469d chore(deps): update all non-major dependencies (v3) (#2529)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-07 11:23:49 +01:00
renovate[bot]
ebbd605ff3 chore(deps): update nuxt framework to ^3.14.159 (v3) (#2547)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-06 19:15:22 +01:00
Benjamin Canac
860e6ed801 chore(module): pass resolver to templates 2024-11-06 16:13:42 +01:00
Benjamin Canac
12ae20df20 fix(module): define #build/app.config
Resolves nuxt/ui#2532
2024-11-06 15:46:05 +01:00
Benjamin Canac
64ad4b6892 fix(NavigationMenu): enforce data-orientation 2024-11-06 15:45:18 +01:00
Benjamin Canac
3c443c631c playground(tooltip): use buttons 2024-11-06 14:57:12 +01:00
Benjamin Canac
104b926c2e docs(deps): update @nuxt/ui-pro 2024-11-06 14:57:03 +01:00
Benjamin Canac
60c574cd01 docs(app): update banner icon 2024-11-06 14:41:41 +01:00
Alex
f821e6681b fix(Table): types in undeclared slots (#2544)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-06 14:27:22 +01:00
Alex
a6c1a6c587 feat(theme)!: migrate from heroicons to lucide (#2540)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-06 12:59:19 +01:00
renovate[bot]
e3092b6b40 chore(deps): update dependency sirv to v3 (v3) (#2538)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-05 22:25:36 +01:00
renovate[bot]
5f99f284ec chore(deps): update dependency nuxt to ^3.14.0 (v3) (#2537)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-05 22:25:04 +01:00
Romain Hamel
701c75a2a8 feat(module): devtools integration (#2196)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-05 22:17:56 +01:00
Benjamin Canac
7fc6b387b3 docs(getting-started): add Vue section 2024-11-05 21:47:12 +01:00
Alex
f66c96e277 feat(DropdownMenu/ContextMenu): handle color field in items (#2510)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-05 21:21:01 +01:00
Malik-Jouda
2d52834529 feat(Badge): handle icon and avatar props (#2497)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-11-05 19:34:40 +01:00
Benjamin Canac
a97c511279 fix(utils): improve escapeRegExp function 2024-11-05 18:03:10 +01:00
Benjamin Canac
50cc034796 chore(deps): dedupe 2024-11-05 15:11:27 +01:00
Benjamin Canac
9f87ea5729 docs(installation): improve callouts 2024-11-05 15:10:13 +01:00
renovate[bot]
eedf287654 chore(deps): update nuxt framework to ^3.14.0 (v3) (#2528)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-04 20:58:02 +01:00
renovate[bot]
28e35da59e chore(deps): update dependency @nuxthub/core to ^0.8.5 (v3) (#2527)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-04 19:39:34 +01:00
renovate[bot]
41eac7ff82 chore(deps): lock file maintenance (v3) (#2520)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-04 14:20:08 +01:00
renovate[bot]
7dd2fd05fc chore(deps): update all non-major dependencies (v3) (#2509)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-11-04 10:29:03 +01:00
Benjamin Canac
845f85a072 fix(useKbd): hydration issue
Related to #2494
2024-11-02 14:29:33 +01:00
Benjamin Canac
120eb920a8 chore(unplugin): improve ui types 2024-11-02 12:50:49 +01:00
Benjamin Canac
1a93d13a16 fix(components): missing relative imports
Resolves nuxt/ui#2515
2024-11-02 12:50:25 +01:00
Benjamin Canac
5a9511fa04 docs(nuxt.config): add typescript lang 2024-10-31 15:44:10 +01:00
Alexander
332c6c08d7 feat(Kbd): special keys for macOS and other systems (#2494)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-10-31 15:14:15 +01:00
Alexander
f26f6c8168 feat(InputMenu/Select/SelectMenu): arrow prop implementation (#2503)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-10-31 15:09:24 +01:00
renovate[bot]
c85ba43040 chore(deps): update all non-major dependencies (v3) (#2495)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-31 14:30:53 +01:00
Benjamin Canac
50918a8128 docs: update to @nuxt/content@next (#2379)
Co-authored-by: Farnabaz <farnabaz@gmail.com>
2024-10-31 14:16:26 +01:00
Benjamin Canac
8669553ea4 fix(Chip): proxy attrs to slot
Resolves nuxt/ui#2484
2024-10-31 12:17:51 +01:00
Benjamin Canac
b416a194df test(NavigationMenu): update vue snapshots 2024-10-31 11:58:25 +01:00
Benjamin Canac
d73c4ddd41 test(ButtonGroup): update vue snapshots 2024-10-31 11:52:33 +01:00
Benjamin Canac
7289eb21e2 chore(deps): remove vue-tsc resolutions 2024-10-31 11:32:12 +01:00
Benjamin Canac
b5ca0d96f1 feat(NavigationMenu): add item-content slot 2024-10-31 11:27:52 +01:00
Benjamin Canac
d980115408 fix(ButtonGroup): merge class with theme
Resolves nuxt/ui#2498
2024-10-31 11:27:19 +01:00
Alexander
ef561e7cba feat(Table): customize header and cell through slots (#2457)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-10-30 15:21:48 +01:00
renovate[bot]
45171e206e chore(deps): lock file maintenance (v3) (#2474)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-30 12:08:17 +01:00
renovate[bot]
ce427f7543 chore(deps): update all non-major dependencies (v3) (#2454)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-10-30 12:01:08 +01:00
Benjamin Canac
309e52faa7 fix(InputMenu/SelectMenu): fast-deep-equal import
Resolves nuxt/ui#2488
2024-10-29 22:15:24 +01:00
Yasser Lahbibi
fc2015bb0e fix(NavigationMenu): improve generic types (#2482)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-10-29 19:21:35 +01:00
Fabian B.
03dd1eba7e fix(Carousel): add missing aria-label on dots (#2489) 2024-10-29 18:31:13 +01:00
Benjamin Canac
77d18d8ab7 fix(templates): type error in app config
Resolves nuxt/ui#2481
2024-10-28 22:43:11 +01:00
Malik-Jouda
94c49186e1 feat(components): improve RTL support (#2433)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-10-28 21:37:01 +01:00
Rihan
e82a82d812 docs(use-toast): add App component warning (#2480) 2024-10-28 21:31:53 +01:00
Yasser Lahbibi
db8111d783 fix(InputMenu/Select/SelectMenu): improve types (#2471) 2024-10-28 18:08:24 +01:00
Sandro Circi
1402436c2b fix(NavigationMenu): add missing min-w-0 to make truncate work (#2476) 2024-10-28 17:13:30 +01:00
Sandro Circi
75410fba97 docs(table): fix examples width (#2478) 2024-10-28 16:55:11 +01:00
Benjamin Canac
0a17663d13 chore(cli): update templates 2024-10-28 16:43:43 +01:00
Benjamin Canac
e592da2fcb fix(Tabs): same behaviour between pill and link variants
Resolves #2338
2024-10-28 10:48:53 +01:00
Benjamin Canac
2514abeb5b chore(github): put back docs typecheck 2024-10-25 17:28:19 +02:00
Daniel Roe
d4a943e631 feat(module): add support for vue using unplugin (#2416)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-10-25 17:15:26 +02:00
Sébastien Chopin
50c6bf0092 chore(deps): update @nuxthub/core (#2459) 2024-10-25 00:00:19 +02:00
renovate[bot]
9cdde9edb2 chore(deps): update tailwindcss to v4.0.0-alpha.30 (v3) (#2458)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-24 23:47:21 +02:00
Benjamin Canac
3f48fdae8d test(Table): import from #components to resolve components 2024-10-24 16:27:39 +02:00
Malik-Jouda
058c49add2 playground(popover): update text (#2452)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-10-24 15:06:55 +02:00
Benjamin Canac
5d4a8ff713 docs(nuxt.config): lint 2024-10-24 14:50:45 +02:00
Benjamin Canac
2af0346654 docs(getting-started): improve faq 2024-10-24 14:35:46 +02:00
Benjamin Canac
f55194e6f0 docs(nuxt.config): clean 2024-10-23 23:49:51 +02:00
Benjamin Canac
eb47a7099d chore(deps): update eslint / @nuxt/eslint-config 2024-10-23 21:35:11 +02:00
Benjamin Canac
68f0269046 chore(release): v3.0.0-alpha.7 2024-10-23 21:27:57 +02:00
Benjamin Canac
47d9955ed9 chore(renovate): ignore resolutions 2024-10-23 21:22:21 +02:00
renovate[bot]
6386a4d99a chore(deps): update all non-major dependencies (v3) (#2418)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-23 21:17:55 +02:00
Benjamin Canac
7687ac16fd docs(table): update 2024-10-23 17:51:28 +02:00
Benjamin Canac
90a775bab9 docs(table): update 2024-10-23 17:49:17 +02:00
renovate[bot]
efeb3f9cfa chore(deps): update tailwindcss to v4.0.0-alpha.29 (v3) (#2440)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-23 17:44:59 +02:00
Benjamin Canac
b54950e3ed feat(Table): implement component (#2364) 2024-10-23 17:32:30 +02:00
Sandro Circi
34bddd45be feat(NavigationMenu): handle children on vertical orientation (#2384)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-10-22 22:52:38 +02:00
Benjamin Canac
69d7b57825 docs(error): update loading indicator color 2024-10-22 12:57:36 +02:00
Benjamin Canac
92873e05ba docs(app): update error 2024-10-22 12:51:42 +02:00
Benjamin Canac
7870288367 docs(app): improve meta 2024-10-22 12:51:32 +02:00
Benjamin Canac
9d3d5db376 docs(deps): update @nuxt/ui-pro 2024-10-22 12:51:18 +02:00
renovate[bot]
090fe16cff chore(deps): update devdependency @nuxt/test-utils to ^3.14.4 (v3) (#2423)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-21 18:21:44 +02:00
renovate[bot]
44ebb35953 chore(deps): lock file maintenance (v3) (#2428)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-21 18:15:17 +02:00
Benjamin Canac
5000a4e0d5 playground(select-menu): add missing placeholder 2024-10-19 18:27:07 +02:00
rizkyyy
5385944359 feat(Form): add superstruct validation (#2363)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
Co-authored-by: Romain Hamel <rom.hml@gmail.com>
2024-10-19 14:07:22 +02:00
Tomy Kho
7802aacf3f fix(InputMenu): emit focus event (#2386)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-10-18 16:09:04 +02:00
Benjamin Canac
f59844bb61 fix(Input/InputMenu/Select/SelectMenu): uniformize placeholder color 2024-10-18 15:48:08 +02:00
Benjamin Canac
9359603a0a docs(input): add examples 2024-10-18 15:42:27 +02:00
Benjamin Canac
d407c42be7 docs(deps): update @nuxt/ui-pro 2024-10-18 15:17:53 +02:00
renovate[bot]
8a06981df2 chore(deps): update tailwindcss to v4.0.0-alpha.28 (v3) (#2412)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-18 15:17:33 +02:00
Benjamin Canac
a68016ec5d fix(Slideover): set max height on top / bottom positions
Resolves nuxt/ui#2388
2024-10-17 22:44:56 +02:00
Benjamin Canac
973023a04e chore(css): move keyframes into separate file 2024-10-17 22:32:26 +02:00
renovate[bot]
f6789a156c chore(deps): update all non-major dependencies (v3) (#2395)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-17 22:15:17 +02:00
Benjamin Canac
61b232377b fix(AvatarGroup): wrong ring on big sizes 2024-10-17 22:14:29 +02:00
Benjamin Canac
eb1b30db40 playground(app): improve responsive navigation 2024-10-17 22:06:34 +02:00
Benjamin Canac
b975235c8b feat(ContextMenu/DropdownMenu): handle loading field in items 2024-10-17 22:03:32 +02:00
Benjamin Canac
81a59969f6 chore(ContextMenu/DropdownMenu): prevent useless extends 2024-10-17 21:47:23 +02:00
Benjamin Canac
dc8cd1e664 docs(components): ignore props in ComponentProps 2024-10-17 21:46:53 +02:00
Benjamin Canac
c63920d05b docs(context-menu/dropdown-menu): improve items properties 2024-10-17 21:25:50 +02:00
Benjamin Canac
37171b9327 chore(components): prevent useless extends on items 2024-10-17 21:25:17 +02:00
Benjamin Canac
49abad243c feat(CommandPalette): handle loading field in items 2024-10-17 21:13:11 +02:00
Benjamin Canac
c1294f6505 chore(components): prioritize icon over avatar in items 2024-10-17 21:06:10 +02:00
Benjamin Canac
53a3796d1b feat(Input/InputMenu/Select/SelectMenu): handle avatar prop 2024-10-17 18:21:12 +02:00
Benjamin Canac
df2013ca92 fix(Button): invalid hover on link variant 2024-10-17 17:41:30 +02:00
Benjamin Canac
0666884b6f docs: use nuxt.png in avatars 2024-10-17 17:10:39 +02:00
Benjamin Canac
a54c3e49fe feat(Button): handle avatar prop 2024-10-17 17:09:59 +02:00
Benjamin Canac
716ed10068 test: consistent avatar urls 2024-10-17 16:33:50 +02:00
Benjamin Canac
e137577a72 docs: consistent avatar urls 2024-10-17 16:31:51 +02:00
Benjamin Canac
0f9349f920 playground: consistent avatar urls 2024-10-17 16:31:41 +02:00
Benjamin Canac
e6143e8600 docs(deps): add wrangler as devDependencies 2024-10-15 18:34:03 +02:00
renovate[bot]
b9380c15ab chore(deps): update tailwindcss to v4.0.0-alpha.27 (v3) (#2263)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-15 18:03:07 +02:00
renovate[bot]
0b7f171268 chore(deps): update all non-major dependencies (v3) (#2382)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-10-15 17:29:53 +02:00
Benjamin Canac
490fb1377b docs(deps): use @nuxt/ui-pro preview release 2024-10-15 17:14:56 +02:00
Benjamin Canac
8ef6e712ac feat(ContextMenu/DropdownMenu): handle checkbox items type
Resolves #2144
2024-10-15 17:14:56 +02:00
Benjamin Canac
0759e29c22 docs(installation): add Continuous Releases section 2024-10-15 17:03:44 +02:00
Benjamin Canac
5385f84e0a chore(github): split docs typecheck 2024-10-15 16:33:17 +02:00
Benjamin Canac
46bd1cb002 docs(carousel): use useTemplateRef 2024-10-15 15:21:53 +02:00
Benjamin Canac
8258cd3829 docs(form): use useTemplateRef 2024-10-15 15:21:42 +02:00
Benjamin Canac
16b48efa96 docs(ThemePicker): remove select event 2024-10-15 15:13:43 +02:00
Benjamin Canac
b39c4d127e fix(components)!: rename select to onSelect on items 2024-10-15 15:13:43 +02:00
renovate[bot]
6af276ef38 chore(deps): update devdependency @release-it/conventional-changelog to v9 (v3) (#2368)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-14 18:31:37 +02:00
renovate[bot]
67fe33f820 chore(deps): update all non-major dependencies (v3) (#2352)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-14 17:55:59 +02:00
renovate[bot]
9e8b9dcc62 chore(deps): lock file maintenance (v3) (#2376)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-14 17:23:43 +02:00
Benjamin Canac
e9affb6f5b docs(command-palette): update 2024-10-14 14:48:14 +02:00
Benjamin Canac
6e9f6a8ef4 docs(accordion): add alert about multiple and v-model
Resolves #2372
2024-10-14 14:47:40 +02:00
Sandro Circi
dcce571cda fix(module): stop using tailwind's shorthand arbitrary variable syntax (#2366)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-10-14 10:42:26 +02:00
Benjamin Canac
ea07dffdd5 chore(github): update issue templates 2024-10-12 19:13:51 +02:00
Benjamin Canac
acfc6cef2d feat(Accordion/Breadcrumb/CommandPalette/ContextMenu/DropdownMenu/NavigationMenu/Tabs): add labelKey prop 2024-10-11 18:30:21 +02:00
Benjamin Canac
f6f9823b15 feat(InputMenu/RadioGroup/Select/SelectMenu): handle labelKey and use get to support dot notation 2024-10-11 15:31:47 +02:00
Benjamin Canac
296ae456c9 chore(components): move utils imports before components 2024-10-11 14:15:44 +02:00
Benjamin Canac
f6631ff7bc fix(Checkbox): indeterminate prop not working 2024-10-11 14:13:46 +02:00
Benjamin Canac
bcfa4b74a9 fix(Drawer/Modal/Slideover): no need for z-index since its isolated
Resolves nuxt/ui#2347
2024-10-11 00:08:17 +02:00
Benjamin Canac
1a7af6d182 test(SelectMenu): update snapshots 2024-10-11 00:07:39 +02:00
Benjamin Canac
558871a46a docs(Header): fix logo focus 2024-10-10 21:11:23 +02:00
Benjamin Canac
c8c17490ab docs(roadmap): fix height 2024-10-10 21:07:50 +02:00
Benjamin Canac
9e03da41b3 fix(css): font-sans already applied on <html> 2024-10-10 17:13:46 +02:00
Benjamin Canac
a2bad2eee2 fix(css): make @theme default 2024-10-10 17:13:05 +02:00
Benjamin Canac
7c21ddefa8 fix(InputMenu/SelectMenu): escape regexp before search 2024-10-10 16:12:22 +02:00
Benjamin Canac
0f9ac8733e fix(InputMenu/SelectMenu): improve displayed value
Resolves nuxt/ui#2353
2024-10-10 16:01:44 +02:00
Benjamin Canac
365bc0fc9a docs(select/select-menu): apply width class on examples
Resolves #2297
2024-10-10 15:34:33 +02:00
Benjamin Canac
c34a805e5f docs: improve hard-coded rounded 2024-10-09 18:24:50 +02:00
Benjamin Canac
b4ffcedd2e docs(deps): update @nuxt/ui-pro 2024-10-09 17:05:35 +02:00
Benjamin Canac
55179ce71c chore(release): v3.0.0-alpha.6 2024-10-09 16:29:01 +02:00
Benjamin Canac
e6d91c94d1 docs(deps): use @nuxt/ui-pro compact url 2024-10-09 16:17:41 +02:00
Benjamin Canac
9026cf2594 chore(release-it): update 2024-10-09 16:00:30 +02:00
renovate[bot]
818ec3893c chore(deps): update all non-major dependencies (v3) (#2344)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-09 15:51:09 +02:00
Benjamin Canac
31b701d9df chore(github): pkg.pr.new compact publish 2024-10-09 15:19:01 +02:00
Benjamin Canac
bee04adf4c fix(Carousel): move embla plugins to dependencies 2024-10-09 15:10:22 +02:00
Sandro Circi
057e86cfda feat(module): implement --ui-radius CSS variable (#2341)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-10-09 14:28:29 +02:00
Benjamin Canac
68ee3f11ca feat(Carousel): implement component (#2288) 2024-10-08 17:12:43 +02:00
renovate[bot]
69a6e11c52 chore(deps): update all non-major dependencies (v3) (#2335)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-08 12:16:57 +02:00
Benjamin Canac
53a4696ed3 docs(installation): improve theme.colors section 2024-10-08 12:05:17 +02:00
Benjamin Canac
7c4ffa56ec chore(module): improve tsdoc 2024-10-08 11:58:23 +02:00
Benjamin Canac
1fc21af918 docs(installation): add warning about shamefully-hoist
TypeScript warning is no longer needed since 6e7a400d4e
2024-10-08 00:51:28 +02:00
renovate[bot]
ede20f89c4 chore(deps): update all non-major dependencies (v3) (#2331)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-07 23:47:22 +02:00
Fabian Hiller
0955c07edd feat(Form): add Standard Schema support (#2303)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-10-07 23:25:52 +02:00
renovate[bot]
aa8fa5be3a chore(deps): update all non-major dependencies (v3) (#2329)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-07 23:20:48 +02:00
renovate[bot]
cf490c3b77 chore(deps): update pnpm to v9.12.1 (v3) (#2328)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-07 15:50:04 +02:00
renovate[bot]
220f659c4c chore(deps): update devdependency @nuxt/test-utils to ^3.14.3 (v3) (#2326)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-07 15:43:17 +02:00
Benjamin Canac
f2e8762b48 docs(deps): use @nuxt/ui-pro@v2 2024-10-07 15:25:07 +02:00
renovate[bot]
c2e879feac chore(deps): update all non-major dependencies (v3) (#2311)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-07 15:18:57 +02:00
Benjamin Canac
3a7c5c2601 fix(Alert): default variant to solid for consistency 2024-10-07 14:57:46 +02:00
Benjamin Canac
9368c6a639 refactor(module)!: implement design system with CSS variables (#2298) 2024-10-07 14:48:02 +02:00
Benjamin Canac
3cf5535b2f fix(Button): center text with block prop
Resolves nuxt/ui#2317
2024-10-07 14:23:24 +02:00
renovate[bot]
cb0081e0a7 chore(deps): update all non-major dependencies (v3) (#2290)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-10-05 23:14:35 +02:00
Benjamin Canac
6e7a400d4e chore(deps): add typescript in peerDependencies 2024-10-05 14:38:52 +02:00
Benjamin Canac
fde75087d0 chore(github): add publish step with pkg-pr-new 2024-10-05 14:05:15 +02:00
Benjamin Canac
7c3ed81309 docs(pages): use title instead of navigation.title in og image 2024-10-02 19:09:07 +02:00
Benjamin Canac
cb44980440 docs(pages): add z-index on toc to go over code examples 2024-10-02 18:51:46 +02:00
Benjamin Canac
6c7c2f02f3 fix(Accordion): use text-left break-words instead of truncate on label 2024-10-02 18:51:32 +02:00
Benjamin Canac
a1ebf8da9a docs(Header): fix badge truncate 2024-10-02 18:47:21 +02:00
Benjamin Canac
ed77b69f5d chore(module): lint 2024-10-02 16:46:11 +02:00
Benjamin Canac
dd42e652d1 docs(deps): update @nuxt/ui-pro 2024-10-02 16:18:29 +02:00
Benjamin Canac
b82af02839 feat(module): set disableTransition option on @nuxtjs/color-mode 2024-10-02 16:18:10 +02:00
Benjamin Canac
e487f2e877 chore(release): v3.0.0-alpha.5 2024-10-02 15:58:14 +02:00
Benjamin Canac
7addc2f70d docs(getting-started): improve faq 2024-10-02 15:57:02 +02:00
Benjamin Canac
0986f5e4b7 docs(Header): display color mode button 2024-10-02 15:57:02 +02:00
Benjamin Canac
077a9210db docs(getting-started): display color-mode page 2024-10-02 15:57:02 +02:00
Benjamin Canac
9dcf903926 feat(module): enable @nuxtjs/color-mode 2024-10-02 15:57:01 +02:00
Benjamin Canac
0f86b87385 feat(module): override dark variant with class strategy 2024-10-02 15:57:01 +02:00
Sébastien Chopin
c9a2631bc3 docs: update link to downloads count badge 2024-10-02 15:53:47 +02:00
Benjamin Canac
1518d0024f chore(README): invalid documentation url 2024-10-02 14:21:54 +02:00
Benjamin Canac
421a193d20 docs(nuxt.config): invalid site.url 2024-10-02 14:21:45 +02:00
Sébastien Chopin
dd54abf243 docs: update GitHub link to v3 branch 2024-10-02 12:45:47 +02:00
Benjamin Canac
c837ca5cc0 docs(getting-started): describe Tailwind CSS @source and @plugin 2024-10-02 12:25:01 +02:00
Benjamin Canac
66a04add91 fix(Button): props specified more than once 2024-10-01 15:31:18 +02:00
Benjamin Canac
a5153d6c8d docs(deps): update @nuxt/ui-pro 2024-10-01 15:24:37 +02:00
Benjamin Canac
cc6db6f14b chore(release): v3.0.0-alpha.4 2024-10-01 15:05:23 +02:00
Benjamin Canac
1f9abdae61 fix(Toast): improve focus styles 2024-10-01 14:50:27 +02:00
Benjamin Canac
f54f607413 fix(build.config): disable mkdist addRelativeDeclarationExtensions option 2024-10-01 14:41:19 +02:00
Benjamin Canac
08db1c68b3 docs(command-palette): update 2024-10-01 11:43:47 +02:00
Benjamin Canac
725833c4a9 cli: fix paths 2024-10-01 11:43:34 +02:00
Benjamin Canac
6a6c43378b chore(CHANGELOG): update from dev 2024-09-30 14:36:51 +02:00
Benjamin Canac
10ab4ce06d docs(composables): clean 2024-09-30 14:33:07 +02:00
Benjamin Canac
afd9b8f2b9 docs(command-palette): use index in example to prevent ts error for now 2024-09-30 14:30:42 +02:00
Benjamin Canac
6aac821e80 docs(roadmap): invalid appConfig access 2024-09-30 14:30:21 +02:00
Benjamin Canac
f4e135d07a test(Drawer): types 2024-09-30 12:48:16 +02:00
Benjamin Canac
ef4a3a09c9 docs(app): put back community links 2024-09-30 12:06:37 +02:00
Benjamin Canac
c738bd9d53 docs(composables): update 2024-09-30 12:01:35 +02:00
Benjamin Canac
aeccf30a92 docs(getting-started): update 2024-09-30 11:44:39 +02:00
Benjamin Canac
673fef1595 docs(nuxt.config): set icon.provider to iconify 2024-09-30 11:12:08 +02:00
renovate[bot]
0ed13f33b5 chore(deps): update all non-major dependencies (v3) (#2265)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-09-30 10:22:11 +02:00
Maxime Pauvert
30c33c7113 fix(README): npm badge link (#2271) 2024-09-30 09:34:26 +02:00
renovate[bot]
fd0ecc6d96 chore(deps): lock file maintenance (v3) (#2279)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-09-30 09:33:49 +02:00
Benjamin Canac
6863254d89 docs(toast): update 2024-09-27 15:37:26 +02:00
Benjamin Canac
d2e075bb4a docs(ComponentExample): improve options handling 2024-09-27 15:37:15 +02:00
Benjamin Canac
6f0b7309c9 docs(drawer): update description 2024-09-27 13:08:15 +02:00
Benjamin Canac
30d9a2653b chore(Link): allow title field 2024-09-27 12:49:32 +02:00
Benjamin Canac
fac52fa933 fix(Drawer): improve max-width on mobile 2024-09-27 12:21:29 +02:00
Benjamin Canac
5f77aac368 feat(Drawer): handle direction + handle props 2024-09-27 11:44:52 +02:00
Benjamin Canac
5b62a8c8ca docs(pagination): update 2024-09-26 17:00:54 +02:00
Benjamin Canac
04a2f2b7a0 chore(Pagination): update defaults 2024-09-26 17:00:43 +02:00
Benjamin Canac
ad3dc26e41 docs(ComponentCode): fix display of false value in select 2024-09-26 16:35:54 +02:00
Benjamin Canac
fd6c1b02ea docs(ComponentCode): handle model prop for cases like v-model:page 2024-09-26 16:21:07 +02:00
Benjamin Canac
19362a9302 chore(deps): update 2024-09-26 16:18:59 +02:00
renovate[bot]
4e2b957882 chore(deps): update dependency @nuxt/fonts to ^0.9.2 (v3) (#2250)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-09-26 15:30:03 +02:00
Benjamin Canac
83ee05dd0e chore(renovate): update 2024-09-26 15:12:25 +02:00
Benjamin Canac
5591854ed4 docs(getting-started): update description 2024-09-26 12:04:24 +02:00
Benjamin Canac
db754740ef docs(input-menu): update 2024-09-26 12:04:12 +02:00
Benjamin Canac
2c7c41bd04 fix(InputMenu): missing group on trailing 2024-09-26 12:00:06 +02:00
Benjamin Canac
9edb23080d docs(define-shortcuts): update 2024-09-25 19:22:44 +02:00
Benjamin Canac
fb8e6a6a66 docs(select-menu): update 2024-09-25 19:07:21 +02:00
Benjamin Canac
183207c2b8 chore(SelectMenu): merge search / searchPlaceholder into searchInput prop 2024-09-25 19:07:11 +02:00
Benjamin Canac
237e7a4e0e docs(nuxt.config): move routeRules cache in $production 2024-09-25 16:56:22 +02:00
Benjamin Canac
cac41137ae docs(getting-started): update 2024-09-25 16:42:40 +02:00
Benjamin Canac
eb0756674a docs(nuxt.config): put back /api/* in cloudflare exclude 2024-09-25 12:34:01 +02:00
Benjamin Canac
9cb863bc21 docs(nuxt.config): remove /api/* in cloudflare exclude 2024-09-25 12:25:27 +02:00
Benjamin Canac
9125a2d467 docs(nuxt.config): try icon serverBundle to remote 2024-09-25 12:19:28 +02:00
Benjamin Canac
0297361319 docs(nuxt.config): update icon options 2024-09-25 12:06:29 +02:00
Sébastien Chopin
749bf90dd1 docs: add auto sub folder 2024-09-25 11:36:05 +02:00
Benjamin Canac
d283887407 docs(nuxt.config): remove experimental.buildCache 2024-09-25 11:07:01 +02:00
Benjamin Canac
d7e46e3637 docs(nuxt.config): remove og-image from cloudflare option 2024-09-25 10:54:41 +02:00
Pooya Parsa
713021f12d docs: enable crawlLinks with exclude patterns (#2246) 2024-09-25 10:44:24 +02:00
Benjamin Canac
1aff74e985 docs(app): update title template 2024-09-25 10:44:05 +02:00
Benjamin Canac
5b3cda741c docs(Header): responsive 2024-09-24 23:10:24 +02:00
Benjamin Canac
a61e7656c2 fix(CommandPalette): missing min-w-0 on root 2024-09-24 23:06:02 +02:00
Benjamin Canac
85b21381e8 docs(app): update loading indicator color 2024-09-24 22:58:34 +02:00
Benjamin Canac
44b98bc7c9 docs(app): use navigation?.title in metas 2024-09-24 22:58:23 +02:00
Benjamin Canac
6c285977bd fix(Accordion): missing min-w-0 on trigger 2024-09-24 22:14:04 +02:00
Benjamin Canac
4c39fa8b0f docs(nuxt.config): add cache 2024-09-24 18:47:13 +02:00
Benjamin Canac
e584941df9 docs: add @nuxthub/core module 2024-09-24 18:28:01 +02:00
Benjamin Canac
991e725b1a docs(nuxt.config): try without crawLinks 2024-09-24 18:16:03 +02:00
Benjamin Canac
b638521ffa docs(public): remove illustrations 2024-09-24 18:08:02 +02:00
Benjamin Canac
2ec978ed0d docs(getting-started): use Public sans to prevent bundle of Inter 2024-09-24 18:02:23 +02:00
Benjamin Canac
b7f9422091 docs: make generate work 2024-09-24 17:53:21 +02:00
Benjamin Canac
d921b764de docs(ComponentCode/ComponentExample): wrong border on light mode 2024-09-24 14:58:40 +02:00
Benjamin Canac
b83ecc9a6f Revert "chore(deps): refresh lock"
This reverts commit cfe4e0bd65.
2024-09-24 14:47:31 +02:00
Benjamin Canac
40f1161b04 docs(app): update font 2024-09-24 14:43:45 +02:00
Benjamin Canac
d419f0a9cb playground(app): update font 2024-09-24 14:43:35 +02:00
Benjamin Canac
7bd06ecfd9 docs(prettier): format in worker like on ssr 2024-09-24 14:43:19 +02:00
Benjamin Canac
cac33c87b2 chore(InputMenu/SelectMenu): handle item select 2024-09-24 14:42:40 +02:00
Benjamin Canac
5e55e15ddf chore(InputMenu/Progress/SelectMenu): clean interfaces for syntax highlight 2024-09-24 14:42:40 +02:00
Benjamin Canac
09d453b5cf docs(ComponentCode/ComponentExample): use justify-center everywhere 2024-09-23 17:16:34 +02:00
Benjamin Canac
4f5a8ee4f6 docs(installation): fix theme.colors option example 2024-09-23 17:14:14 +02:00
Benjamin Canac
cfe4e0bd65 chore(deps): refresh lock 2024-09-23 11:59:32 +02:00
renovate[bot]
1932aa2671 chore(deps): update all non-major dependencies (v3) (#2230)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-09-23 11:45:16 +02:00
Anthony Fu
cc8fa471e9 chore: replace dev time flag for build (#2231)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-09-23 11:00:51 +02:00
Benjamin Canac
19bfc36976 test(Input): add missing file type 2024-09-23 10:52:02 +02:00
Benjamin Canac
7d754c0015 chore(components): add newline before script to correct syntax highlight 2024-09-20 23:20:39 +02:00
Benjamin Canac
8709717a32 docs(command-palette): update 2024-09-20 18:45:52 +02:00
Benjamin Canac
32ac575d56 chore(README): update 2024-09-20 17:54:30 +02:00
Benjamin Canac
c39996c0fe docs(app): increase container size 2024-09-20 15:39:47 +02:00
renovate[bot]
235f1cc330 chore(deps): update all non-major dependencies (v3) (#2219)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-09-20 14:16:59 +02:00
Benjamin Canac
f45b39937b docs(command-palette): update 2024-09-18 17:32:01 +02:00
Benjamin Canac
a70ba04fc3 chore(Alert): rename close event to update:open for consistency 2024-09-18 17:31:42 +02:00
Benjamin Canac
500b4727e8 docs(ComponentExample): update 2024-09-18 15:00:23 +02:00
Benjamin Canac
d36576b1fe chore(module): gray now defaults to slate 2024-09-18 12:21:50 +02:00
Benjamin Canac
6498f8a0c1 test: move colors into theme.colors 2024-09-18 12:20:12 +02:00
Benjamin Canac
96c9246d83 fix(templates): app config colors type 2024-09-18 12:19:46 +02:00
Benjamin Canac
e45398f6ce docs(playground): update theme 2024-09-18 12:14:33 +02:00
Benjamin Canac
a32d2c034a docs(app): update theme 2024-09-18 12:14:23 +02:00
Benjamin Canac
f52310d4a1 docs(deps): use @nuxt/ui-pro 2024-09-18 11:33:56 +02:00
Benjamin Canac
a6ae1dcb1d chore(release): v3.0.0-alpha.3 2024-09-18 11:31:39 +02:00
Benjamin Canac
2e954467c4 feat(module): move colors options into theme.colors 2024-09-18 11:28:31 +02:00
Benjamin Canac
d3317d828e docs: use shiki-transformer-color-highlight (#2215) 2024-09-18 10:54:59 +02:00
Benjamin Canac
2c3032e363 chore(release): v3.0.0-alpha.2 2024-09-18 10:32:18 +02:00
Romain Hamel
dd6bf5694f fix(Button): duplicate click handlers (#2213)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-09-18 10:18:32 +02:00
Benjamin Canac
a8b26eb1a8 playground(link): fix urls 2024-09-17 18:34:33 +02:00
Benjamin Canac
df72003516 docs(getting-started): update 2024-09-17 16:39:45 +02:00
Benjamin Canac
1f5372baba docs(app): display pages descriptions in markdown 2024-09-17 16:36:00 +02:00
Benjamin Canac
d4efd13307 docs(IconsTheme): omit @nuxt/ui-pro icons 2024-09-17 16:35:47 +02:00
Benjamin Canac
87c0a0f9c1 chore(package): add missing description 2024-09-17 12:33:55 +02:00
Benjamin Canac
d5339d3ebe docs(ComponentCode): fix boolean type 2024-09-17 11:36:44 +02:00
Benjamin Canac
ff8eefdce7 chore(theme): clean Select & InputMenu 2024-09-17 11:25:35 +02:00
Benjamin Canac
2346f52cbf chore(components): missing some props.ui merging 2024-09-17 11:25:16 +02:00
Benjamin Canac
d0a669ee2e chore(deps): update 2024-09-16 12:52:48 +02:00
Benjamin Canac
7e672bd041 docs: ts errors 2024-09-16 12:51:36 +02:00
Romain Hamel
ed18e74549 feat(Button): loading-auto (#2198) 2024-09-16 11:37:38 +02:00
Benjamin Canac
6f20f243fb docs(getting-started): update 2024-09-15 21:44:10 +02:00
Benjamin Canac
ce91b5d75a docs(command-palette): update 2024-09-12 18:29:23 +02:00
Benjamin Canac
d9b14bc325 docs(navigation-menu): remove useless classes 2024-09-12 18:29:13 +02:00
Benjamin Canac
d0ac6f95a4 docs(getting-started): update 2024-09-12 18:29:01 +02:00
Benjamin Canac
8f76caa7f8 docs(ComponentCode): add slug prop 2024-09-12 18:27:15 +02:00
Benjamin Canac
336631434c docs(deps): update nuxt-component-meta 2024-09-12 16:45:29 +02:00
Romain Hamel
319fce136f docs(form): update (#2167)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-09-12 15:47:58 +02:00
Benjamin Canac
1667e5a655 chore(deps): set nuxt-component-meta resolution 2024-09-12 15:22:30 +02:00
Benjamin Canac
ad77a0e82d docs: fix refactor 2024-09-12 15:22:10 +02:00
Benjamin Canac
5076b8cc9e feat(module): improve options 2024-09-12 12:43:12 +02:00
Benjamin Canac
2fc6e18179 docs(getting-started): update 2024-09-12 12:42:23 +02:00
Benjamin Canac
8898a5d675 feat(module): install @nuxt/fonts by default 2024-09-12 12:42:23 +02:00
Bernardo Oliveira
7c2adf2f7f fix(Button): button link not showing disabled classes (#2189) 2024-09-12 12:25:24 +02:00
Romain Hamel
523493105e docs: types (#2186) 2024-09-12 11:10:23 +02:00
renovate[bot]
26e5ac80b6 chore(deps): update all non-major dependencies (v3) (#2184)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-09-12 10:44:19 +02:00
Benjamin Canac
a83e3821a4 docs(getting-started): update 2024-09-11 19:20:54 +02:00
Benjamin Canac
ea8a083d84 docs(index): update 2024-09-11 18:56:13 +02:00
Romain Hamel
cf92c5f3f0 fix(playground): typecheck 2024-09-11 18:53:19 +02:00
renovate[bot]
594bc9bb2e chore(deps): update all non-major dependencies (v3) (#2182)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-09-11 16:39:56 +02:00
Benjamin Canac
7e87f05840 docs(nuxt.config): remove prerender 2024-09-11 16:02:42 +02:00
Benjamin Canac
942f087a67 docs(nuxt.config): prerender routes 2024-09-11 12:24:52 +02:00
Benjamin Canac
13975da684 docs(deps): update @nuxt/ui-pro 2024-09-11 11:49:56 +02:00
Benjamin Canac
4198a42dff chore(release): v3.0.0-alpha.1 2024-09-11 10:38:54 +02:00
Benjamin Canac
21609aa884 chore(package): update release script 2024-09-11 10:36:54 +02:00
Benjamin Canac
82771673f2 fix(types): no longer need to import types with /index suffix
Solved in https://github.com/unjs/mkdist/pull/244
2024-09-11 10:34:59 +02:00
Benjamin Canac
4f83a2829e chore(deps): update 2024-09-11 10:34:21 +02:00
Benjamin Canac
debf9cc853 fix(plugins): infer type from #app to remove build warning 2024-09-11 10:30:15 +02:00
Benjamin Canac
40b3570343 fix(templates): augment @nuxt/schema rather than nuxt/schema 2024-09-10 17:01:39 +02:00
Benjamin Canac
95d2b7a56e docs(Banner): update icon 2024-09-10 16:26:26 +02:00
Benjamin Canac
c6171d0f8d docs: use Inter font 2024-09-10 16:26:19 +02:00
Benjamin Canac
625c4efa03 docs(installation): update 2024-09-10 15:37:41 +02:00
Benjamin Canac
d8d7b8fcc5 docs(components): update github links to nuxt/ui repository 2024-09-10 15:34:09 +02:00
Benjamin Canac
c578acbb88 chore(deps): refresh lock 2024-09-10 15:00:50 +02:00
Benjamin Canac
3e30775fd4 docs(IconsTheme): format without prettier to improve performances 2024-09-10 15:00:50 +02:00
Benjamin Canac
ec84f777ea docs(radio-group): link value to Value Key title 2024-09-10 15:00:50 +02:00
Benjamin Canac
a2a303f527 docs(HighlightInlintType): hide undefined in types 2024-09-10 15:00:50 +02:00
Benjamin Canac
3d0e1eb288 docs(components): ignore prefetchOn prop 2024-09-10 15:00:50 +02:00
Romain Hamel
175229384f chore(Form): catch-up with v2 changes (#2165)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-09-10 14:09:42 +02:00
renovate[bot]
9ddfec123e chore(deps): update pnpm to v9.10.0 (v3) (#2164)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-09-09 18:29:29 +02:00
Benjamin Canac
1f0e515c33 chore(App): types 2024-09-09 18:12:23 +02:00
Benjamin Canac
3e28c8f35a fix: import from ../types/index 2024-09-09 18:00:39 +02:00
Benjamin Canac
9d8bb80892 chore(deps): refresh lock 2024-09-09 15:39:50 +02:00
Benjamin Canac
8b8ec22af7 docs(deps): update nuxt-component-meta 2024-09-09 13:53:32 +02:00
Benjamin Canac
4b09358ce0 chore(deps): update 2024-09-09 12:22:41 +02:00
Benjamin Canac
4f339be363 playground(app): improve from @nuxt/ui-pro 2024-09-06 19:02:31 +02:00
Benjamin Canac
7d28d99f10 playground(app): improve from @nuxt/ui 2024-09-06 19:02:31 +02:00
Benjamin Canac
71428da3dc fix(README): license link 2024-09-06 19:02:31 +02:00
Benjamin Canac
4a7433d628 chore(package): export style 2024-09-06 19:02:31 +02:00
Romain Hamel
8c886279b2 test(Form): fix (#2153) 2024-09-06 18:58:24 +02:00
Benjamin Canac
62a2643a80 feat(module): hard-code css file to be imported anywhere 2024-09-06 17:27:06 +02:00
Benjamin Canac
7cd3cc4aa6 chore(module): update nuxt compatibility 2024-09-06 17:26:43 +02:00
Benjamin Canac
07b0cf9979 chore(deps): update 2024-09-06 16:51:51 +02:00
Benjamin Canac
c94041d656 chore(github): update workflows 2024-09-06 15:27:11 +02:00
Benjamin Canac
97d05936cd fix(useButtonGroup): lint 2024-09-06 15:22:07 +02:00
Benjamin Canac
a03a55cf8d fix(ContextMenu/DropdownMenu): lint unused var 2024-09-06 15:21:56 +02:00
Benjamin Canac
1716ba0f5e docs(navigation-menu): update 2024-09-06 14:59:05 +02:00
Benjamin Canac
a8b5bff8c6 docs(ComponentExample): update 2024-09-06 13:00:23 +02:00
Benjamin Canac
84186e52e9 fix(NavigationMenu): handle open state hover effect 2024-09-06 13:00:05 +02:00
Benjamin Canac
7fe7ff6fe2 fix(Link): only bind necessary slot props 2024-09-06 12:57:04 +02:00
Benjamin Canac
aa34e3c141 chore(package): remove engines 2024-09-06 11:57:52 +02:00
Benjamin Canac
d989ceb09d chore(vercel): disable deployments 2024-09-06 09:53:19 +02:00
Benjamin Canac
403d3b2718 docs(deps): use @nuxt/ui-pro@2.0.0-alpha.1 2024-09-06 09:53:06 +02:00
Benjamin Canac
08039c1dcd chore(release): v3.0.0-alpha.0 2024-09-05 17:19:00 +02:00
Benjamin Canac
d107ba1e7a chore(release-it): handle publish 2024-09-05 16:56:06 +02:00
Benjamin Canac
a6e5db477d chore(release-it): remove hooks 2024-09-05 16:53:16 +02:00
Benjamin Canac
0b7a724d5f chore(vercel): prevent deployment on v3 branch 2024-09-05 16:24:42 +02:00
Benjamin Canac
eb85fa8353 fix(templates): import from #build/ui.css no longer works 2024-09-05 16:19:49 +02:00
Benjamin Canac
e36a48c684 docs(ComponentCode): update 2024-09-05 16:19:28 +02:00
Benjamin Canac
2934a280e8 docs(navigation-menu): update 2024-09-05 16:19:09 +02:00
Benjamin Canac
9af06e95cc docs(nuxt.config): update 2024-09-05 16:18:56 +02:00
Benjamin Canac
843f822b8c chore(github): add ci for v3 branch 2024-09-05 16:13:44 +02:00
Benjamin Canac
de0133e177 chore(components): use useId from vue 2024-09-05 16:00:30 +02:00
Benjamin Canac
9c4e8f2dba chore(module): remove useless @ts-expect-error 2024-09-05 16:00:02 +02:00
Benjamin Canac
5ede4033be chore(deps): update 2024-09-05 15:59:48 +02:00
Benjamin Canac
b8f815ccca docs(components): fix github links 2024-09-05 12:02:21 +02:00
Benjamin Canac
c710cf0ddc docs(index): update 2024-09-05 11:46:59 +02:00
Benjamin Canac
4b168a887e chore(cli): update templates 2024-09-05 11:46:53 +02:00
Benjamin Canac
2c30025ca1 chore(templates): tailwind.css eol indentation 2024-09-05 10:37:50 +02:00
Benjamin Canac
47ad74d029 fix(components): allow override of root through ui.root 2024-09-05 10:37:39 +02:00
Benjamin Canac
59201e3a67 docs(components): update 2024-09-05 10:23:08 +02:00
Benjamin Canac
fba4d6a385 docs(composables): update 2024-09-05 10:22:58 +02:00
Benjamin Canac
85d172339f feat(Accordion): add body slot to solve animation flick 2024-09-04 17:50:38 +02:00
Benjamin Canac
d63ab0892e chore(cli): update templates 2024-09-04 17:40:46 +02:00
Benjamin Canac
29a9be2fdf docs(separator): update 2024-09-04 11:36:19 +02:00
Benjamin Canac
7c18232932 docs(toast): update 2024-09-04 11:36:05 +02:00
Benjamin Canac
e91cba741c docs(dropdown-menu/radio-group/select): update callouts type 2024-09-04 11:06:32 +02:00
Benjamin Canac
045c44c139 docs(carousel/table): update badge 2024-09-04 11:06:02 +02:00
Benjamin Canac
577436d190 docs(composables): add use-toast page 2024-09-04 11:05:51 +02:00
Benjamin Canac
efd1a81184 docs(components): update props ignore 2024-09-04 11:05:21 +02:00
Benjamin Canac
54814a2562 chore(App): typo in slots interface 2024-09-04 10:21:09 +02:00
Benjamin Canac
b3de942696 docs(ComponentProps): display schema default in description 2024-09-04 10:20:01 +02:00
Benjamin Canac
eb2667fa81 docs(ComponentTheme): avoid using prettier to improve performances 2024-09-04 09:40:02 +02:00
Benjamin Canac
9f49796bd7 docs(alert): add missing Description section 2024-09-03 16:42:46 +02:00
Benjamin Canac
fe78529640 docs(context-menu): add missing Extract shortcuts section 2024-09-03 16:42:28 +02:00
Benjamin Canac
b6cb72de64 docs(select): update 2024-09-03 16:23:06 +02:00
Benjamin Canac
c2b9948a07 chore(RadioGroup/Select): remove useless as any on valueKey 2024-09-03 15:37:02 +02:00
Benjamin Canac
52e2fd75c2 chore(icons): remove useless empty key 2024-09-03 15:36:32 +02:00
Benjamin Canac
6b79b4fd22 docs(radio-group): update 2024-09-03 12:16:09 +02:00
Benjamin Canac
850e84c0e0 feat(RadioGroup): handle value-key prop 2024-09-03 12:16:09 +02:00
Benjamin Canac
9c1171f61d docs(checkbox/slider/switch): hide defaultValue select in code examples 2024-09-03 12:15:55 +02:00
Benjamin Canac
be383e415d docs(ComponentCode): handle two-way binding on modelValue 2024-09-03 12:15:55 +02:00
Benjamin Canac
6f4fdb163c chore(deps): update 2024-09-03 10:56:06 +02:00
Benjamin Canac
0e355d323b chore(deps): update tailwindcss 2024-08-24 12:33:57 +02:00
Benjamin Canac
dee404f24f test: update snapshots 2024-08-23 18:39:35 +02:00
Benjamin Canac
2aa4358d32 fix(InputMenu/Select/SelectMenu): use defuFn to override base slot 2024-08-23 18:39:15 +02:00
Benjamin Canac
dd1452a452 chore(deps): set happy-dom resolution to 14.12.3 2024-08-23 18:38:10 +02:00
Benjamin Canac
9ceb4cc6c1 chore(InputMenu/Select/SelectMenu): clean code 2024-08-23 18:33:31 +02:00
Benjamin Canac
2a20a0a541 docs(collapsible): update 2024-08-23 17:22:12 +02:00
Benjamin Canac
7673e51e20 docs(popover): update 2024-08-23 17:22:06 +02:00
Benjamin Canac
9dd9d5126a docs(collapsible): update 2024-08-23 16:44:00 +02:00
Benjamin Canac
99f5a66090 docs: update 2024-08-23 16:19:19 +02:00
Benjamin Canac
a261028f6e chore: script setup order definition 2024-08-23 16:02:46 +02:00
Benjamin Canac
6a10b27b98 playground(modal/slideover): update 2024-08-23 16:02:28 +02:00
Benjamin Canac
6ac63b5034 docs(slideover): update 2024-08-23 16:02:12 +02:00
Benjamin Canac
1d1d88d6ee docs(ComponentExample): handle preview: false 2024-08-23 16:01:57 +02:00
Benjamin Canac
60f2b0d8fb docs(modal): update 2024-08-23 13:26:20 +02:00
Benjamin Canac
4b641f7c23 chore(deps): update 2024-08-22 23:47:31 +02:00
Benjamin Canac
d430256271 chore(colors): use media query instead of .dark selector
Waiting on Tailwind CSS v4 dark mode implementation
2024-08-22 23:13:04 +02:00
Benjamin Canac
daf430b10d docs(nuxt.config): use --background variable on root element 2024-08-22 23:12:18 +02:00
Benjamin Canac
5428005512 docs(drawer): update 2024-08-22 16:58:47 +02:00
Benjamin Canac
7b278b041c fix(fuse): prevent indices highlight of a single char 2024-08-22 16:57:05 +02:00
Benjamin Canac
1ef977fb8c feat(CommandPalette): handle filter false and postFilter 2024-08-22 15:41:49 +02:00
Benjamin Canac
d558b3e29c fix(CommandPalette): ts errors 2024-08-22 14:29:58 +02:00
Benjamin Canac
8dfac7fd57 feat(module): add @source when @nuxt/content is present 2024-08-22 12:07:49 +02:00
Benjamin Canac
92f4d38cc3 docs: lint on catch undefined e 2024-08-22 12:07:17 +02:00
Benjamin Canac
b7382f2057 docs(header): add color picker 2024-08-21 16:12:38 +02:00
Benjamin Canac
ac0267b14c chore(components): bind props.ui?.content on content elements 2024-08-20 18:39:10 +02:00
Benjamin Canac
c3000d5ce6 docs: rename og image dir 2024-08-20 18:32:02 +02:00
Benjamin Canac
b838dd1458 chore(eslint): disable @typescript-eslint/no-empty-object-type 2024-08-20 18:29:12 +02:00
Benjamin Canac
b4568b31cf test: update snapshots 2024-08-20 18:29:00 +02:00
Benjamin Canac
561c1fb665 fix(Button): move span with truncate inside default slot 2024-08-20 18:28:47 +02:00
Benjamin Canac
55cbc65825 chore(deps): refresh lock 2024-08-20 17:56:32 +02:00
Benjamin Canac
283b3c9ac0 chore(renovate): enable lockfile maintenance 2024-08-20 17:00:27 +02:00
Benjamin Canac
695085cac4 chore(deps): update 2024-08-20 16:33:03 +02:00
Benjamin Canac
88e94cc10b chore(github): put back labels in issue templates 2024-08-07 15:35:30 +02:00
Benjamin Canac
71d27152ed docs(context-menu): update 2024-08-07 14:51:01 +02:00
Benjamin Canac
9af6d7dc59 fix(ContextMenu/DropdownMenu): move open and default-open props to Sub 2024-08-07 13:20:48 +02:00
Benjamin Canac
5d2d198aae docs(ComponentCode/ComponentExample/ComponentTheme): handle collapse 2024-08-07 12:27:47 +02:00
Benjamin Canac
daa98c56fa chore(ContextMenu/DropdownMenu): set modal to true by default 2024-08-06 18:37:03 +02:00
Benjamin Canac
5e294e7e21 docs(ComponentTheme/IconsTheme): wrap around defineAppConfig 2024-08-06 18:27:40 +02:00
Benjamin Canac
db8c0e7433 chore(pnpm): remove modules/* from workspace 2024-08-06 17:10:30 +02:00
Benjamin Canac
39a63e8e3f docs(dropdown-menu): update 2024-08-06 17:10:30 +02:00
Benjamin Canac
8d560bdd21 feat(module): allow tailwind.css customization 2024-08-06 12:55:11 +02:00
Benjamin Canac
d13e27eb5b feat(Breacrumb/ContextMenu/DropdownMenu/NavigationMenu): bind item class on link 2024-08-06 12:52:01 +02:00
Benjamin Canac
10bb9b486a docs(accordion): update 2024-08-06 12:42:09 +02:00
Benjamin Canac
279f55ee2c docs(tabs): update 2024-08-06 12:41:47 +02:00
Benjamin Canac
8da6a1c0e2 docs(button): improve ui prop formatting 2024-08-06 11:22:01 +02:00
Benjamin Canac
68afba8f3c docs(ComponentProps): handle ignore in schema 2024-08-06 11:22:01 +02:00
Benjamin Canac
24f24e9d8e docs(progress/slider): improve orientation section 2024-08-06 11:22:01 +02:00
Benjamin Canac
34ba466c15 docs(collapsible): update 2024-08-06 11:22:01 +02:00
Benjamin Canac
8f5e8170e6 docs(ComponentCode/ComponentExample): add class prop 2024-08-06 11:22:01 +02:00
Benjamin Canac
e70aee4d69 docs: update 2024-08-06 11:22:01 +02:00
Benjamin Canac
15cee52003 chore(deps): update 2024-08-05 12:43:31 +02:00
Benjamin Canac
13738d574b chore(Alert/Toast): remove template around description 2024-08-04 11:34:55 +02:00
Benjamin Canac
fff3d04415 chore(deps): add nuxt resolution to 3.12.3 2024-08-02 14:30:00 +02:00
Benjamin Canac
b1bcaabd19 fix(RadioGroup): style legend based on size 2024-08-01 17:18:21 +02:00
Benjamin Canac
e598ca5b40 docs: clean 2024-08-01 17:17:52 +02:00
Benjamin Canac
787ab001bd chore(deps): update 2024-08-01 17:17:28 +02:00
Benjamin Canac
372d902f7e docs(link): update 2024-08-01 15:13:42 +02:00
Benjamin Canac
e94461d1fa docs(form-field): update 2024-08-01 12:12:40 +02:00
Benjamin Canac
9963d71fbc docs(getting-started): inverse icons and colors 2024-08-01 12:08:37 +02:00
Benjamin Canac
5366e228bb docs: update banner title 2024-08-01 12:08:24 +02:00
Benjamin Canac
789fcb6566 docs: use present tense when possible 2024-08-01 12:05:09 +02:00
Benjamin Canac
a23c3140df fix(FormField): allow error prop as boolean 2024-08-01 11:51:07 +02:00
Benjamin Canac
d93e151194 docs(progress/slider): update orientation height 2024-07-31 16:46:32 +02:00
Benjamin Canac
b9f4bcbbc9 docs(collapsible): update 2024-07-31 16:44:32 +02:00
Benjamin Canac
973560e6f1 docs(meter): hide 2024-07-31 16:04:48 +02:00
Benjamin Canac
9426513a59 docs: rename Events to Emits 2024-07-31 15:59:06 +02:00
Benjamin Canac
6ea576c558 docs(ComponentCode): fix code when number | number[] 2024-07-31 15:57:06 +02:00
Benjamin Canac
836007dfa6 docs(progress): update 2024-07-31 15:53:34 +02:00
Benjamin Canac
00575f55c9 docs(ComponentCode): ignore externals manually 2024-07-31 15:52:04 +02:00
Benjamin Canac
8f48883a2d docs(ComponentCode): improve 2024-07-31 15:28:37 +02:00
Benjamin Canac
74a6bca2b3 feat(Input/Textarea): expose ref 2024-07-31 15:28:28 +02:00
Benjamin Canac
c3ee509c65 docs(radio-group): update 2024-07-31 14:16:23 +02:00
Benjamin Canac
b9e3fcb0f1 docs(slider): update 2024-07-31 12:52:29 +02:00
Benjamin Canac
0635c5434c chore(Slider): improve update:modelValue event signature 2024-07-31 11:22:56 +02:00
Benjamin Canac
007a0cf85e docs(switch): update 2024-07-31 11:13:46 +02:00
Benjamin Canac
c4ef5c4db8 docs(textarea): update 2024-07-30 19:18:02 +02:00
Benjamin Canac
4eea9f54c0 docs(input): update 2024-07-30 19:04:06 +02:00
Benjamin Canac
4eb1732545 docs(ComponentCode): allow empty string in v-model 2024-07-30 18:03:09 +02:00
Benjamin Canac
a6d5e188a3 docs(ComponentProps/ComponentSlots): remove white-space 2024-07-30 18:02:56 +02:00
Benjamin Canac
9a8d44c46b docs(ComponentCode): improve slots display 2024-07-30 17:47:49 +02:00
Benjamin Canac
8f82a65f03 docs(tooltip): update 2024-07-30 16:46:49 +02:00
Benjamin Canac
cae27d5206 chore(Collapsible): add flex flex-col gap-2 on root 2024-07-30 16:46:42 +02:00
Benjamin Canac
0ddadc9b3b docs(checkbox): remove examples 2024-07-30 16:46:07 +02:00
Benjamin Canac
a90935b6aa docs(chip): update 2024-07-30 16:45:53 +02:00
Benjamin Canac
2c6295d479 docs(ComponentProps/ComponentSlots): add whitespace pre 2024-07-30 16:45:42 +02:00
Benjamin Canac
4dd799748b chore(deps): update 2024-07-30 15:04:41 +02:00
Benjamin Canac
bcaca46ccc docs(chip): update 2024-07-26 16:13:02 +02:00
Benjamin Canac
2f57c43361 docs(components): update callouts priorities 2024-07-26 16:11:24 +02:00
Benjamin Canac
aca319bc36 docs(components): split color and variant into two sections 2024-07-26 15:17:46 +02:00
Benjamin Canac
3a1ba1dfa3 docs(checkbox): update 2024-07-26 14:59:56 +02:00
Benjamin Canac
09f76e75a9 docs(checkbox): update 2024-07-26 13:03:32 +02:00
Benjamin Canac
b9249c0c3d docs(components): demo size different than default 2024-07-26 13:03:24 +02:00
Benjamin Canac
a6c4ffa013 docs(ComponentCode/ComponentExample): disable prettier by default 2024-07-26 13:02:55 +02:00
Benjamin Canac
839b97a9dc docs(components): update descriptions 2024-07-26 11:58:43 +02:00
Benjamin Canac
ce28607d7d docs(app): update 2024-07-26 11:05:20 +02:00
Benjamin Canac
3319144962 chore(module): add support for non vite projects 2024-07-26 10:47:34 +02:00
Benjamin Canac
9569339c91 chore(deps): update tailwindcss 2024-07-26 10:47:18 +02:00
Benjamin Canac
42f4f8d337 fix(module): use relative imports to components / composables 2024-07-25 18:17:20 +02:00
Benjamin Canac
8bac288687 docs(accordion): update 2024-07-24 17:22:12 +02:00
Benjamin Canac
3c1d8162ca docs(alert): update 2024-07-24 16:59:14 +02:00
Benjamin Canac
f1193c35c5 docs(ComponentProps): update 2024-07-24 16:59:07 +02:00
Benjamin Canac
7757d330b0 docs(tabs): add Content section 2024-07-24 15:54:03 +02:00
Benjamin Canac
5114136d25 docs(ComponentProps): improve display 2024-07-24 15:53:31 +02:00
Benjamin Canac
5176bf92bc chore(Accordion): remove useless content prop 2024-07-24 15:33:28 +02:00
Benjamin Canac
30de2373c5 docs(breadcrumb): improve 2024-07-24 15:32:44 +02:00
Benjamin Canac
aa301af926 docs(Tabs): improve 2024-07-24 15:32:35 +02:00
Benjamin Canac
102fb2316d docs(ComponentProps): display schema description 2024-07-24 14:48:33 +02:00
Benjamin Canac
c00e0fa3db docs: remove unused pages 2024-07-24 14:28:16 +02:00
Benjamin Canac
e1b0936105 docs(tabs): update examples 2024-07-24 14:22:02 +02:00
Benjamin Canac
ecad41a7fa docs(tooltip): update 2024-07-24 14:21:53 +02:00
Benjamin Canac
1d9ac2b75b docs(icon): update link 2024-07-23 16:50:29 +02:00
Benjamin Canac
023a5215bf docs(components): add first prop title in usage to be displayed in toc 2024-07-23 16:50:18 +02:00
Benjamin Canac
4825b754fc chore(App): typo in interfaces 2024-07-23 16:49:40 +02:00
Benjamin Canac
be8bf691c3 fix(Tooltip): missing root props proxy 2024-07-23 12:19:06 +02:00
Benjamin Canac
fb6eae3f62 docs(ComponentCode): improve 2024-07-23 12:18:23 +02:00
Benjamin Canac
ec0f599565 docs(tabs): update 2024-07-22 16:32:06 +02:00
Benjamin Canac
d6950d3df8 chore(deps): update 2024-07-22 16:07:55 +02:00
Benjamin Canac
640de11ec7 docs(breadcrumb): update examples 2024-07-22 16:07:45 +02:00
Benjamin Canac
f4db34bf1c docs(ComponentCode): missing overflow 2024-07-22 16:07:26 +02:00
Benjamin Canac
c1ac3a9f9d fix(Link): allow ariaLabel to be picked 2024-07-22 12:52:28 +02:00
Benjamin Canac
6cc635a8a7 test: add missing /components in urls 2024-07-22 12:52:12 +02:00
Benjamin Canac
0ad74794ed playground(context-menu): improve 2024-07-22 12:48:04 +02:00
Benjamin Canac
dc3d714ded playground: add missing /components in urls 2024-07-22 12:47:49 +02:00
Benjamin Canac
a7e73f86de chore(deps): update @nuxt/icon 2024-07-20 18:16:56 +02:00
Benjamin Canac
b28b0f9d8c chore(deps): update 2024-07-20 18:15:24 +02:00
Benjamin Canac
78f8740369 docs(tabs): update 2024-07-18 18:07:28 +02:00
Benjamin Canac
ca8e9e77ab docs(progress): update 2024-07-18 17:51:26 +02:00
Benjamin Canac
5317c5724f docs(define-shortcuts): update 2024-07-18 17:51:20 +02:00
Benjamin Canac
35f72351d0 docs(avatar): update 2024-07-18 17:51:07 +02:00
Benjamin Canac
8364de98c9 docs(alert): add examples 2024-07-18 17:49:34 +02:00
Benjamin Canac
368054456b docs(breadcrumb): update 2024-07-18 17:48:03 +02:00
Benjamin Canac
067e2d346e docs: use camelCase in props 2024-07-18 17:46:54 +02:00
Benjamin Canac
01ac65f07d docs(ComponentCode): update 2024-07-18 17:45:35 +02:00
Benjamin Canac
d7c1158f97 docs(ComponentCode): handle hide and external props 2024-07-18 15:39:11 +02:00
Benjamin Canac
b194c5e49a docs(alert): update 2024-07-18 15:39:01 +02:00
Benjamin Canac
c824f300c3 docs(ComponentExample): use $prettier for consistency 2024-07-18 15:34:40 +02:00
Benjamin Canac
82ea62bb23 docs(button-group): update 2024-07-18 14:12:17 +02:00
Benjamin Canac
ff678d6004 docs(ComponentCode): update prettier options 2024-07-18 14:10:10 +02:00
Benjamin Canac
0c4b79f92e docs(breadcrumb): update 2024-07-18 11:25:00 +02:00
Benjamin Canac
0dfd8b3248 fix(ButtonGroup): define its own size variant 2024-07-18 11:24:40 +02:00
Benjamin Canac
70b964f3a0 docs(avatar-group): update 2024-07-18 11:06:26 +02:00
Benjamin Canac
3b5a7c5c58 chore(github): update stale workflow 2024-07-18 10:52:58 +02:00
Benjamin Canac
eff468fe9c docs(app): update 2024-07-17 18:02:47 +02:00
Benjamin Canac
98a802bfed docs(ComponentCode): update 2024-07-17 18:02:40 +02:00
Benjamin Canac
6db7b056ae docs(skeleton): update 2024-07-17 17:38:34 +02:00
Benjamin Canac
9c56917714 docs(avatar-group): update 2024-07-17 17:27:34 +02:00
Benjamin Canac
8ae8993db4 docs(ComponentCode): handle input number 2024-07-17 17:27:14 +02:00
Benjamin Canac
9620d903c5 fix(AvatarGroup): default size to md 2024-07-17 17:17:46 +02:00
Benjamin Canac
e9832b95f5 fix(AvatarGroup): handle deep children 2024-07-17 17:17:15 +02:00
Benjamin Canac
b5bfb61816 docs(breadcrumb): update example 2024-07-17 17:02:36 +02:00
Benjamin Canac
da42c0489a fix(Avatar): bind $attrs on image 2024-07-17 16:39:37 +02:00
Benjamin Canac
b0e0b87c79 docs(avatar): update 2024-07-17 16:39:27 +02:00
Benjamin Canac
df6e2a6378 docs(ComponentCode): update prettier config 2024-07-17 16:39:09 +02:00
Benjamin Canac
59b3873c73 docs(ComponentProps): always put as first and ui last 2024-07-17 16:38:47 +02:00
Benjamin Canac
c3f747aee5 docs(alert): update 2024-07-17 15:44:38 +02:00
Benjamin Canac
dd532bb110 docs(ComponentCode): handle objects 2024-07-17 15:44:17 +02:00
Benjamin Canac
11b4dfefa7 chore(components): add lang ts-type on close buttons jsdoc 2024-07-17 15:25:28 +02:00
Benjamin Canac
a155e7c1a7 chore(github): update 2024-07-17 14:59:46 +02:00
Benjamin Canac
8ba5637f61 chore(Alert): improve gray color 2024-07-17 14:59:33 +02:00
Benjamin Canac
09c6fce8eb docs(ComponentProps): add ? when prop is optional 2024-07-17 11:55:19 +02:00
Benjamin Canac
4e99ebf605 docs(ComponentCode/ComponentExample): add missing margin 2024-07-17 11:55:02 +02:00
Benjamin Canac
8563ea157b docs(breadcrumb): update 2024-07-17 11:54:39 +02:00
Benjamin Canac
59a84f2ace chore(deps): update 2024-07-16 21:28:49 +02:00
Benjamin Canac
9420a686bb docs(components): update radix-vue links labels 2024-07-11 18:18:33 +02:00
Benjamin Canac
e7e1b2339f docs(container): update 2024-07-11 17:43:03 +02:00
Benjamin Canac
a890528550 docs(fetchComponentExample): prevent err when example is not found 2024-07-11 17:42:48 +02:00
Benjamin Canac
795621746b docs(card): update 2024-07-11 17:38:34 +02:00
Benjamin Canac
96e18ef233 docs(ComponentExample): add 2024-07-11 17:38:27 +02:00
Benjamin Canac
57e62f36c4 docs: use ::tip everywhere 2024-07-11 17:15:12 +02:00
Benjamin Canac
b9319c0fbc docs(icon): update 2024-07-11 17:14:59 +02:00
Benjamin Canac
810ea32bf8 docs(fetchComponentMeta): handle case where component doesn't exist 2024-07-11 17:14:45 +02:00
Benjamin Canac
c712e2e682 docs(ComponentCode): handle case where theme doesn't exist 2024-07-11 17:14:27 +02:00
Benjamin Canac
c1ed04f722 chore(Toast): simplify code now that duration is exposed 2024-07-11 12:51:00 +02:00
Benjamin Canac
6a13c7fa01 chore(deps): update 2024-07-11 12:50:44 +02:00
Benjamin Canac
a73d1c6ae6 chore(vscode): remove settings 2024-07-11 10:29:20 +02:00
Benjamin Canac
c1ddedf67a docs(link): update 2024-07-10 19:07:06 +02:00
Benjamin Canac
612a9e930d docs(kbd): update 2024-07-10 18:44:08 +02:00
Benjamin Canac
bfeba51b8a docs(components): update github links 2024-07-10 18:43:59 +02:00
Benjamin Canac
40d17f7b03 fix(Kbd): optional value prop when using default slot 2024-07-10 18:43:30 +02:00
Benjamin Canac
bc633c6687 docs(ComponentCode): handle custom items 2024-07-10 18:43:06 +02:00
Benjamin Canac
8e5547f26d docs(content): move shortcuts into composables/ 2024-07-10 17:22:42 +02:00
Benjamin Canac
a889c054d3 docs(ComponentCode): handle objects 2024-07-10 17:22:24 +02:00
Benjamin Canac
813fdfd646 fix(SelectMenu): display modelValue even if false 2024-07-10 15:24:18 +02:00
Benjamin Canac
982e12f2b8 docs(button): update 2024-07-10 15:23:47 +02:00
Benjamin Canac
f16eb2310d docs(badge): update 2024-07-10 15:23:27 +02:00
Benjamin Canac
26f68fc31d docs: improve ComponentCode and ComponentProps 2024-07-10 15:23:21 +02:00
Benjamin Canac
6aa0ea306f feat(components): allow override of sizes through ui prop 2024-07-10 12:57:34 +02:00
Benjamin Canac
db30284e7a feat(SelectMenu): add prop to disable search 2024-07-10 12:56:38 +02:00
Benjamin Canac
781047eacb docs(badge): update 2024-07-09 18:11:41 +02:00
Benjamin Canac
5a13e1bf41 docs: add ComponentCode component 2024-07-09 18:11:33 +02:00
Benjamin Canac
bdc3217571 fix(CommandPalette/InputMenu/Select/SelectMenu): adapt chip size 2024-07-09 17:44:46 +02:00
Benjamin Canac
5c12d428c4 fix(SelectMenu): adapt input size 2024-07-09 17:17:53 +02:00
Benjamin Canac
9d0db51ccc playground: move pages under /components to match docs 2024-07-09 17:08:16 +02:00
Benjamin Canac
eeec9676cd feat(InputMenu/Select/SelectMenu): introduce valueKey prop
Resolves #108
2024-07-09 17:03:52 +02:00
Benjamin Canac
06e8a9e912 chore(CommandPalette/InputMenu/SelectMenu): proxy selectedValue prop from Combobox 2024-07-09 17:02:34 +02:00
Benjamin Canac
7fd38a8cb8 fix(module): typo in fuchsia color 2024-07-09 15:44:21 +02:00
Benjamin Canac
182d4dd81a docs: update 2024-07-09 15:24:23 +02:00
Benjamin Canac
eba8b4b31a feat(Input): set autocomplete to off by default 2024-07-09 15:24:07 +02:00
Benjamin Canac
e1f385ee76 playground(checkbox): remove icon on error color 2024-07-09 15:22:55 +02:00
Benjamin Canac
9078da5279 chore(templates): improve DeepPartial type 2024-07-09 12:26:04 +02:00
Benjamin Canac
c7536a7af9 fix(templates): add error in AppConfig type 2024-07-09 12:17:34 +02:00
Benjamin Canac
510433568a chore(Tabs): avatar type 2024-07-09 12:14:38 +02:00
Benjamin Canac
d94f8b7452 chore(deps): update 2024-07-09 11:22:29 +02:00
Benjamin Canac
12e9ec28ae chore(github): update pnpm/action-setup to v4 2024-07-09 11:01:29 +02:00
Benjamin Canac
c018c23224 feat(components): uniformize colors and variants (#141) 2024-07-09 10:45:26 +02:00
Silver343
18c5ead1bd feat(InputMenu): handle size prop (#131)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-07-03 15:32:16 +02:00
Benjamin Canac
6f535ade9c docs(icons): dynamic theme section 2024-07-03 15:25:05 +02:00
Benjamin Canac
a4e86d6d42 chore(components): add more sizes to theme config 2024-07-03 15:23:43 +02:00
Benjamin Canac
5f40773fa4 docs(ComponentProps): prevent err 2024-07-03 14:36:16 +02:00
Benjamin Canac
235556d3e0 fix(components): ui prop override with class (#136) 2024-07-03 14:35:58 +02:00
Benjamin Canac
5a22c62b2a docs(nuxt.config): add content highlight diff lang 2024-07-02 15:45:59 +02:00
Benjamin Canac
5cc4457a74 fix(components): declare ui prop with PartialString when arrays in theme slots 2024-07-02 15:02:29 +02:00
Benjamin Canac
52146dc260 docs(nuxt.config): update 2024-07-02 14:53:26 +02:00
Benjamin Canac
cacd853d1e chore(components): declare slots after emits 2024-07-02 13:54:29 +02:00
Benjamin Canac
1eaec0ff56 fix(templates): export types in dev mode 2024-07-02 13:45:43 +02:00
Sandro Circi
b61696cdca feat(Select/SelectMenu): handle size prop (#133)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-07-02 12:03:10 +02:00
Benjamin Canac
57a49877ae playground: update 2024-07-02 10:30:14 +02:00
Benjamin Canac
f4c9f530b8 docs: update 2024-07-02 10:26:46 +02:00
Silver343
aa832f32a0 feat(ContextMenu): handle size prop (#130) 2024-07-02 10:26:23 +02:00
Romain Hamel
bad2e49de9 refactor(Form): input events (#99)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-07-01 20:37:57 +02:00
Benjamin Canac
ca029a4b6c docs: update 2024-07-01 19:35:59 +02:00
Benjamin Canac
c8e353e599 docs(ComponentTheme): filter compoundVariants colors and display warning 2024-07-01 18:40:28 +02:00
Benjamin Canac
18311d32d8 docs: improve props 2024-07-01 17:26:03 +02:00
Benjamin Canac
d2be8fdf7d chore(components): improve jsdoc 2024-07-01 16:22:08 +02:00
Benjamin Canac
ccbaf6ea15 feat(module)!: move primary and gray inside colors object 2024-07-01 14:57:59 +02:00
Benjamin Canac
30bc3a1d76 chore(module): move animations to css file 2024-07-01 14:57:59 +02:00
Benjamin Canac
a39cbd3a7f chore(Button): improve outline, soft and ghost variants 2024-07-01 14:57:59 +02:00
Benjamin Canac
509bf6fec6 chore(Badge): improve soft and subtle variants 2024-07-01 14:30:08 +02:00
Benjamin Canac
2eb6a234c3 chore(Alert): improve soft and subtle variants 2024-07-01 14:29:55 +02:00
Benjamin Canac
4362de48a7 chore(deps): refresh lock 2024-07-01 11:57:19 +02:00
Benjamin Canac
fbb82c29cd chore(deps): update 2024-07-01 11:21:40 +02:00
Romain Hamel
20acc92eec feat(Form): support for valibot@33 (#132) 2024-07-01 10:52:27 +02:00
Benjamin Canac
225d28d279 docs(form): improve Exposed section 2024-06-28 22:32:58 +02:00
Benjamin Canac
e3da411014 docs(ComponentEvents): improve name 2024-06-28 22:10:19 +02:00
Benjamin Canac
f9c69a7837 chore(components): use {} for empty props 2024-06-28 22:03:14 +02:00
Benjamin Canac
8113c2163c docs(HighlightInlineType): use ts-type language 2024-06-28 21:35:57 +02:00
Benjamin Canac
88aace9263 chore(deps): add @nuxtjs/mdc resolution to latest edge 2024-06-28 21:35:40 +02:00
Benjamin Canac
84cc647f83 chore(components): improve props jsdoc 2024-06-28 18:36:46 +02:00
Benjamin Canac
ec08ed9e2e docs(deps): update nuxt-component-meta to v0.7.0 2024-06-28 18:35:49 +02:00
Benjamin Canac
ef2b270a04 docs: display jsdoc defaultValue 2024-06-28 18:13:21 +02:00
Benjamin Canac
673064dee5 chore(components): improve props 2024-06-28 18:13:03 +02:00
Benjamin Canac
c9f9a248b7 docs: update 2024-06-28 16:19:25 +02:00
Benjamin Canac
fae627ed65 chore(components): add missing emits for docs 2024-06-28 16:19:06 +02:00
Benjamin Canac
7dd90f2bb7 docs(app): use UContentSearchButton component 2024-06-28 14:29:41 +02:00
Benjamin Canac
24618b8a5e docs(deps): update nuxt-component-meta to v0.6.6 2024-06-28 14:29:22 +02:00
Benjamin Canac
4ef81991f2 docs: update 2024-06-28 11:51:23 +02:00
Benjamin Canac
db45bafaed chore(Button): ignore raw from LinkProps 2024-06-28 11:51:23 +02:00
Benjamin Canac
a44abb738f chore(deps): update 2024-06-28 11:51:23 +02:00
Benjamin Canac
a0559d4163 chore: ignore as from radix props fields 2024-06-28 11:51:23 +02:00
Benjamin Canac
f85eb8ed40 chore(Alert/Toast): remove description as VNode 2024-06-28 11:51:23 +02:00
Benjamin Canac
369e0b1952 fix: define empty props in slots for nuxt-component-meta parsing 2024-06-28 11:51:23 +02:00
Benjamin Canac
84d814f88b docs: update 2024-06-27 16:35:28 +02:00
Anthony Fu
1d61d8d152 docs: highlight inline type code in props table 2024-06-27 16:28:11 +02:00
Benjamin Canac
b5f42cdd3a docs: update 2024-06-27 15:39:15 +02:00
Benjamin Canac
0b3ce24eb6 docs: update 2024-06-26 19:09:05 +02:00
Benjamin Canac
c63b3cec6a chore(deps): refresh lock 2024-06-25 18:47:44 +02:00
Benjamin Canac
3097da486f fix(module): prevent override of rootAttrs.class 2024-06-25 18:14:17 +02:00
Benjamin Canac
c72cb58441 chore(deps): remove vue-tsc resolution 2024-06-25 18:10:22 +02:00
Benjamin Canac
cd7cc0d9a3 chore: improve types export 2024-06-25 17:58:14 +02:00
Benjamin Canac
ea288e9624 chore(deps): refresh lock 2024-06-24 17:58:39 +02:00
Benjamin Canac
bdecefa2d1 chore(deps): remove happy-dom resolution 2024-06-24 17:39:27 +02:00
Benjamin Canac
86f5884f08 chore(deps): pin vue-tsc 2024-06-24 17:37:50 +02:00
Benjamin Canac
5f7872f06e fix(types): useless import 2024-06-24 17:30:05 +02:00
Benjamin Canac
b22aedd9d7 chore(deps): update pnpm 2024-06-24 12:20:09 +02:00
Benjamin Canac
0bdfc26734 chore(deps): update 2024-06-24 11:44:17 +02:00
Benjamin Canac
0b8bfa887b docs(deps): update @nuxt/content and move content/ outside of app/ 2024-06-20 10:39:10 +02:00
Benjamin Canac
11ef256db7 docs: improve 2024-06-19 21:23:23 +02:00
Benjamin Canac
dc1913b40d playground(dropdown-menu): update icon 2024-06-19 18:00:35 +02:00
Benjamin Canac
a5b3608938 chore(Button): improve variants
Resolves #118
2024-06-19 13:03:43 +02:00
Silver343
dfa99362d4 feat(DropdownMenu): handle size prop (#125)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-06-19 11:50:25 +02:00
Benjamin Canac
5b2e7d8bad fix(Select): wrong button group variants 2024-06-19 11:01:34 +02:00
Benjamin Canac
6a72ef06d0 docs: highlight navigation 2024-06-19 10:48:06 +02:00
Benjamin Canac
34cf395f1a fix(Tooltip): put back close animation 2024-06-19 10:35:30 +02:00
Benjamin Canac
865b57f97c chore(github): update actions 2024-06-18 17:21:40 +02:00
Benjamin Canac
5a0d70e33d chore(deps): use @nuxt/icon instead of nuxt-icon 2024-06-18 12:39:44 +02:00
Benjamin Canac
06e041c374 docs: update 2024-06-18 11:01:00 +02:00
Benjamin Canac
cd7888cac7 chore(deps): update 2024-06-18 11:00:41 +02:00
Benjamin Canac
20d49d9e16 chore(DropdownMenu/ContextMenu): type createReusableTemplate 2024-06-15 10:35:21 +02:00
Benjamin Canac
0c6720be73 fix(module): add isolate class on root node 2024-06-15 10:30:06 +02:00
Benjamin Canac
38fb22af19 chore(module): add ts-ignore on nuxt.options.ui assignment 2024-06-15 10:29:55 +02:00
Benjamin Canac
8f1402f780 chore(module): indicate compatibility with new v4 major 2024-06-15 10:26:58 +02:00
Benjamin Canac
bedb863fc6 fix(SelectMenu): input before empty 2024-06-13 11:17:51 +02:00
Benjamin Canac
20995aa6d3 docs: migrate to nuxt compatibility 4 2024-06-12 11:10:59 +02:00
Benjamin Canac
ceee9b2e11 playground: migrate to nuxt compatibility 4 2024-06-12 10:36:47 +02:00
Benjamin Canac
ee3d2aa30f chore(components): improve JSDoc 2024-06-11 18:23:56 +02:00
Benjamin Canac
655d9b2c97 chore(Button): remove truncate prop to always use on label 2024-06-11 17:39:27 +02:00
Benjamin Canac
e4eef89767 feat(Alert/CommandPalette/Modal/Slideover/Toast): handle closeIcon and uniformize close prop 2024-06-11 15:48:45 +02:00
Benjamin Canac
d160278283 chroe(deps): pin happy-dom 2024-06-11 15:48:03 +02:00
Benjamin Canac
884a14c3d2 chore(deps): update 2024-06-11 14:03:12 +02:00
Benjamin Canac
e5695e78bc fix(Breadcrumb): only apply aria-current="page" when link is active 2024-06-11 12:26:41 +02:00
Benjamin Canac
33713b200d chore(deps): update 2024-06-11 12:00:04 +02:00
Benjamin Canac
c630625e83 chore: add class in close slot props 2024-06-10 18:57:18 +02:00
Benjamin Canac
90bcc23576 cli: typo when writing types/index.d.ts 2024-06-10 18:57:00 +02:00
Benjamin Canac
1d303ab909 playground: use app.head instead of useHead 2024-06-10 15:59:30 +02:00
Benjamin Canac
b56151e144 chore(RadioGroup): expose modeValue in label / description slots 2024-06-10 11:41:33 +02:00
Benjamin Canac
0f2da5bb15 chore(Switch): improve props JSDoc 2024-06-10 11:17:42 +02:00
Benjamin Canac
d8189052be chore(CommandPalette): improve props JSDoc 2024-06-10 11:14:44 +02:00
Romain Hamel
a2114c5874 fix(Form): inconsistent validation events for InputMenu and Select (#123)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-06-10 10:45:54 +02:00
Benjamin Canac
f2d3e53dec chore(deps): update tailwindcss 2024-06-09 17:11:40 +02:00
Benjamin Canac
9dd9b3426c test(CommandPalette): update 2024-06-08 16:14:30 +02:00
Benjamin Canac
9d5f9a7010 fix(Tabs): align link variant left when vertical 2024-06-08 16:14:23 +02:00
Silver343
2b6965211d feat(Tabs): handle size prop (#124)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-06-08 16:03:51 +02:00
Benjamin Canac
5694823a41 fix(templates): pass options to theme in dev mode 2024-06-07 19:54:48 +02:00
Benjamin Canac
5511e21eeb chore(package): use DEV=true only with nuxi dev 2024-06-07 19:53:57 +02:00
Anthony Fu
12ba480d34 fix(module): handle theme HMR on dev (#84)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-06-07 19:47:59 +02:00
Benjamin Canac
efb7582b37 chore(defineShortcuts): lint 2024-06-07 19:38:22 +02:00
Benjamin Canac
b503876e20 chore(deps): update lock 2024-06-07 19:36:37 +02:00
Benjamin Canac
6a1b97add0 fix(templates): missing command in keyframes 2024-06-07 19:36:37 +02:00
Neil Richter
b886150147 feat(Slideover): open programmatically (#122) 2024-06-07 17:31:05 +02:00
Benjamin Canac
20476f4b9a feat(CommandPalette): improve theme and performance 2024-06-07 16:01:30 +02:00
Benjamin Canac
4e17da21f3 chore: remove space in function type def 2024-06-07 11:58:39 +02:00
Benjamin Canac
09e4cb77f1 chore(Navigation): typo in type 2024-06-07 11:57:29 +02:00
Benjamin Canac
e29cf793cb feat(CommandPalette): implement group filter function 2024-06-06 18:35:48 +02:00
Benjamin Canac
dc761a8e3e chore(CommandPalette): improve theme 2024-06-06 15:08:23 +02:00
Benjamin Canac
15e707c4ad chore(CommandPalette): warn when group is missing id 2024-06-06 15:08:10 +02:00
Benjamin Canac
0ee60c015b chore(Drawer/Modal/Slideover): increase overlay z-index to 50 2024-06-06 15:05:46 +02:00
Benjamin Canac
ada68a6637 chore(icons): sort 2024-06-06 15:04:41 +02:00
Benjamin Canac
5f4fd972ff feat(module): add option to disable transitions 2024-06-05 23:11:58 +02:00
Benjamin Canac
3f2b1b12cd chore(theme): improve options type 2024-06-05 22:42:06 +02:00
Benjamin Canac
ecc2240df0 cli: handle --prose && --content options for pro 2024-06-05 17:04:26 +02:00
Benjamin Canac
f70b63970a fix(Tabs): wrong text color with pill colored 2024-06-05 16:04:50 +02:00
Benjamin Canac
188d2bcd89 chore(module): dedup colors 2024-06-05 15:53:28 +02:00
Benjamin Canac
2de38b317b chore(module): add JSDoc for options 2024-06-05 15:53:05 +02:00
Benjamin Canac
88eb4cac97 fix(Tabs): improve config 2024-06-05 15:46:07 +02:00
Benjamin Canac
82ffc1ed57 feat(Tabs): handle color and variant props
Resolves #116
2024-06-05 15:09:59 +02:00
Benjamin Canac
57b32ca9b6 playground(alert): improve actions color 2024-06-04 14:06:14 +02:00
Benjamin Canac
ad70bb9a59 playground(app): fix layout scroll 2024-06-04 14:06:03 +02:00
Benjamin Canac
b1879ea6d1 chore(NavigationMenu): consistent key for child link external icon 2024-06-04 12:43:09 +02:00
Benjamin Canac
e051ef682a feat(Tabs): handle content prop as boolean 2024-06-03 14:55:33 +02:00
Benjamin Canac
c6880c2036 chore(deps): update 2024-06-03 11:20:59 +02:00
Benjamin Canac
f975fb64bd playground(form): clean 2024-05-30 17:29:00 +02:00
Benjamin Canac
eb1a60d320 chore(DropdownMenu): types 2024-05-30 17:28:52 +02:00
Benjamin Canac
395b8305e1 chore(Breadcrumb): improve theme 2024-05-30 17:28:41 +02:00
Benjamin Canac
ed2c45ac76 feat: expose open state to slots 2024-05-30 12:36:48 +02:00
Benjamin Canac
85c4226bd0 chore(Breadcrumb): font-medium on active link only 2024-05-30 12:03:30 +02:00
Benjamin Canac
5a6a827b42 chore(RadioGroup): consistent emits 2024-05-30 12:03:15 +02:00
Benjamin Canac
3fc06ed1da test(NavigationMenu): improve 2024-05-29 14:41:35 +02:00
Benjamin Canac
ff77967fd7 test(RadioGroup): improve 2024-05-29 14:41:23 +02:00
Benjamin Canac
dfc63b1bc0 chore(ButtonGroup): use Primitive and improve tests 2024-05-29 14:41:13 +02:00
Benjamin Canac
627688cab5 chore(NavigationMenu): improve theme 2024-05-29 14:32:57 +02:00
Benjamin Canac
c838b3a040 fix(NavigationMenu): add default highlightColor 2024-05-28 18:12:35 +02:00
Benjamin Canac
440593c5e4 fix(Pagination): center text when link 2024-05-28 17:18:16 +02:00
Neil Richter
2bf99e1eb4 feat(Modal): open programmatically (#78)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-05-28 17:14:13 +02:00
Benjamin Canac
cf38e7ed78 fix(module): inject options in nuxt.options.ui 2024-05-28 16:39:25 +02:00
Benjamin Canac
0bdd6dfe86 fix(NavigationMenu): highlightColor defaults to color prop 2024-05-28 16:39:05 +02:00
Benjamin Canac
af43b5df25 feat(NavigationMenu): replace line variant with highlight prop 2024-05-28 15:29:22 +02:00
Benjamin Canac
ec6ebbacbe feat(NavigationMenu): improve theme with line variant and border 2024-05-28 11:28:01 +02:00
Benjamin Canac
1af449d6e0 feat(NavigationMenu): handle content, color, variant, etc. 2024-05-27 15:03:50 +02:00
Benjamin Canac
bcab07a32c playground(app): update layout 2024-05-27 14:52:00 +02:00
Benjamin Canac
88926091d5 test: missing props in with ui 2024-05-27 14:51:44 +02:00
Benjamin Canac
c9c685a01c chore(Breadcrumb): improve theme config 2024-05-27 14:50:40 +02:00
Benjamin Canac
51f4ffc953 chore(DropdownMenu/ContextMenu): handle external icon 2024-05-27 14:49:22 +02:00
Benjamin Canac
a8dfa0ff29 chore(DropdownMenu/ContextMenu): item type default to link 2024-05-27 14:47:57 +02:00
Benjamin Canac
316eeea482 docs: start migration 2024-05-22 12:42:30 +02:00
Romain Hamel
072f2c64f7 playground(form): examples for SelectMenu and InputMenu (#112)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-05-22 10:25:35 +02:00
Neil Richter
5c5676edf9 feat(Pagination): allow using pagination buttons as links (#114) 2024-05-21 17:51:52 +02:00
Benjamin Canac
e8dee1efe1 chore(Select): expose modelValue and open
Resolves #109
2024-05-20 17:50:48 +02:00
Benjamin Canac
d2442a1e47 fix(Progress): initial indicator style when percent is 0 2024-05-20 14:19:22 +02:00
Benjamin Canac
b497e427df chore(deps): update 2024-05-20 14:17:32 +02:00
Benjamin Canac
034062df65 chore(Link): add pickLinkProps util 2024-05-17 11:58:31 +02:00
Benjamin Canac
9970f0ea6b chore(Breadcrumb): improve links hover style 2024-05-17 11:52:24 +02:00
Benjamin Canac
f1b9e27ff7 chore(Tabs): improve trigger transition 2024-05-16 17:21:57 +02:00
Benjamin Canac
08c91fe8f1 feat(Checkbox/Progress/RadioGroup/Slider/Switch): add black color 2024-05-16 15:30:15 +02:00
Benjamin Canac
633a39452a feat: add transition-colors on hover effects 2024-05-16 13:09:47 +02:00
Benjamin Canac
2e174c7d20 chore(Button): improve subtle variant hover state 2024-05-16 12:22:31 +02:00
Benjamin Canac
39144b6515 cli: wrong default slot 2024-05-16 12:18:56 +02:00
Sandro Circi
138cb2d12d feat(Progress): new component (#75)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-05-15 15:26:07 +02:00
Benjamin Canac
9037a1d94c chore(Chip): wrong ui typeof 2024-05-15 14:47:26 +02:00
Benjamin Canac
f833628751 cli: make it executable 2024-05-15 12:47:08 +02:00
Benjamin Canac
c753da3cbe chore(deps): update 2024-05-14 15:05:03 +02:00
Benjamin Canac
fe3ab652b4 feat(InputMenu): handle multiple
Resolves #91
2024-05-14 12:37:51 +02:00
Benjamin Canac
27ffb8d8ab feat(SelectMenu): handle multiple prop
Resolves #102
2024-05-13 16:12:06 +02:00
Benjamin Canac
7a376b5e49 feat(SelectMenu): new component (#103) 2024-05-13 14:26:01 +02:00
Romain Hamel
8baee1292f fix(Chip): size injection (#105) 2024-05-13 10:15:24 +02:00
Benjamin Canac
c00ec5e2f2 fix(Select): missing comma in &nbsp; 2024-05-10 19:12:12 +02:00
Benjamin Canac
ff9fd9f657 fix(InputMenu): bind searchTerm with defineModel 2024-05-10 19:11:55 +02:00
Benjamin Canac
8b8b7ca40f chore(deps): update 2024-05-10 19:11:24 +02:00
Benjamin Canac
659d5e2c5a feat(InputMenu): expose modelValue and open to slots 2024-05-10 18:16:28 +02:00
Benjamin Canac
45454fae45 fix(useComponentIcons): reactivity when using defu 2024-05-10 17:57:53 +02:00
Romain Hamel
52cf471099 feat(Form): Select and InputMenu integration (#97)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-05-10 12:53:52 +02:00
Romain Hamel
810d278ea7 chore(RadioGroup): rename options prop to items (#98)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-05-10 12:31:20 +02:00
Benjamin Canac
2480efe6e5 chore(deps): update 2024-05-10 10:49:33 +02:00
Benjamin Canac
1942b8e117 feat(Select): new component (#92) 2024-05-07 22:58:56 +02:00
Benjamin Canac
4a123906d0 chore(deps): update 2024-05-07 11:19:35 +02:00
Romain Hamel
43066fd9ea feat(ButtonGroup): new component (#88)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-05-07 11:19:25 +02:00
Benjamin Canac
2c5d7ccf70 test(Drawer): update snapshots after upgrade 2024-05-06 22:03:49 +02:00
Benjamin Canac
e398637174 fix(Textarea): same size as input 2024-05-06 22:03:38 +02:00
Benjamin Canac
15cb9a023d chore(deps): update 2024-05-06 21:55:50 +02:00
Benjamin Canac
99f20a4154 feat(InputMenu): new component (#86) 2024-05-06 18:59:49 +02:00
Benjamin Canac
f409395297 test: update snapshots 2024-05-06 12:16:19 +02:00
Romain Hamel
a9a1746486 chore: use InjectionKey to type and define injected properties (#90) 2024-05-06 10:45:36 +02:00
Benjamin Canac
63822c3cf6 chore(CommandPalette): remove useless theme slot 2024-05-02 15:42:06 +02:00
Benjamin Canac
4ac7a7e3e9 fix(ContextMenu): remove arrow prop 2024-05-02 15:41:54 +02:00
Benjamin Canac
e5bec87488 chore(Checkbox): improve props 2024-05-02 15:38:43 +02:00
Benjamin Canac
dcf83261f3 playground(dropdown-menu): update custom slot badge 2024-05-02 15:38:28 +02:00
Benjamin Canac
68202d80ec chore(deps): use nuxt-icon beta (#83)
Co-authored-by: Anthony Fu <anthonyfu117@hotmail.com>
2024-05-02 15:31:12 +02:00
Benjamin Canac
a1b78bf619 chore(deps): update 2024-05-02 15:29:44 +02:00
Benjamin Canac
063a30916c chore(CommandPalette): extend disabled prop from radix 2024-05-02 15:15:53 +02:00
Benjamin Canac
ec142c3c20 chore(NavigationMenu): extend value prop from radix 2024-05-02 15:15:53 +02:00
Benjamin Canac
e8358ea967 chore(ContextMenu): extend disabled prop from radix 2024-05-02 15:15:53 +02:00
Benjamin Canac
8a2efd9b51 chore(DropdownMenu): extend disabled prop from radix 2024-05-02 15:15:53 +02:00
Benjamin Canac
1069e226ee chore(Tabs): extend value / disabled props from radix 2024-05-02 15:15:53 +02:00
Benjamin Canac
30a4f06e86 chore(Accordion): extend value / disabled props from radix 2024-05-02 15:15:53 +02:00
Anthony Fu
e5f0063dba fix: specify pnpm version (#85)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-05-02 15:15:11 +02:00
Benjamin Canac
f039d1a7dd chore(CommandPalette): define placeholder from InputProps 2024-05-02 10:41:02 +02:00
Benjamin Canac
d0017bf847 feat(CommandPalette): new component (#80) 2024-04-30 18:14:18 +02:00
Mauro Erta
559a8cba58 fix(FormField): added a utility type to fix some type errors (#81)
Co-authored-by: Mauro Erta <mauro.erta@sap.com>
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-04-29 18:12:09 +02:00
Benjamin Canac
46bd407b91 chore(deps): update radix-vue and ui-pro file path 2024-04-29 18:07:48 +02:00
Benjamin Canac
fb783d22b6 chore(Button): remove aria-hidden from icons 2024-04-29 11:26:03 +02:00
Benjamin Canac
0450f6b4a9 fix(Tooltip): use scale-in / scale-out animations 2024-04-29 11:21:44 +02:00
Benjamin Canac
67a15686e5 fix(Input/Textarea): remove useless gap 2024-04-29 11:21:44 +02:00
Benjamin Canac
2363b0a4f1 docs(deps): use @nuxt/ui-pro from file 2024-04-28 17:56:17 +02:00
Benjamin Canac
fc50996ccf fix(Checkbox): icon render 2024-04-28 17:55:24 +02:00
Benjamin Canac
aed4100a41 test(Chip): update snapshots 2024-04-28 17:54:59 +02:00
Benjamin Canac
72ac394476 chore(Accordion): add missing shrink-0 on trailing icon 2024-04-28 17:54:46 +02:00
Benjamin Canac
f90f7d7b7c fix(Popover): use scale-in / scale-out animations 2024-04-28 17:54:32 +02:00
Benjamin Canac
16071846a8 chore(FormField): rename inputId to id 2024-04-28 11:46:24 +02:00
Benjamin Canac
65e916d09a test: setup file path not working when using vscode extension 2024-04-28 11:45:39 +02:00
Benjamin Canac
36cf8ccf21 chore(deps): update 2024-04-28 11:45:03 +02:00
Benjamin Canac
58da6ebe83 chore(ContextMenu): invalid kbds prop type definition 2024-04-27 22:33:54 +02:00
Benjamin Canac
ce28e662d6 chore: uniformize defineModel placement and emits 2024-04-27 22:16:41 +02:00
Benjamin Canac
def5f7c10b feat(AvatarGroup): new component (#71)
Co-authored-by: Romain Hamel <romain@boilr.io>
2024-04-26 17:04:49 +02:00
Benjamin Canac
26bfdfc54d playground(deps): specify only nuxt version 2024-04-26 14:54:20 +02:00
Benjamin Canac
65a3b0a2d0 feat(ContextMenu): new component
Resolves #18
2024-04-26 14:53:50 +02:00
Benjamin Canac
51872bef6c feat(Toast): add actions slot 2024-04-25 17:57:25 +02:00
Benjamin Canac
2d157090c0 feat(Alert): add actions slot 2024-04-25 17:57:18 +02:00
Benjamin Canac
26491afcd1 fix(Alert): add missing close slot 2024-04-25 17:57:07 +02:00
Benjamin Canac
5a84095da6 chore(DropdownMenu): omit content on links 2024-04-25 12:12:01 +02:00
Benjamin Canac
3708dfaea6 chore(DropdownMenu): item disabled is inherited from Link 2024-04-25 12:11:39 +02:00
Benjamin Canac
e36345c4db chore(NavigationMenu): omit value on links 2024-04-25 12:10:59 +02:00
Benjamin Canac
f48755f116 test: improve 2024-04-25 11:53:15 +02:00
Benjamin Canac
ebdaacfb9f chore(Toaster): missing slots definition 2024-04-25 11:49:39 +02:00
Benjamin Canac
67661174b0 test(DropdownMenu): consistent items with playground 2024-04-25 11:48:47 +02:00
Benjamin Canac
a5bb25dd95 feat(DropdownMenu): handle item type separator 2024-04-25 11:48:27 +02:00
Benjamin Canac
7d67b4d000 test(NavigationMenu): consistent items with playground 2024-04-25 11:45:24 +02:00
Benjamin Canac
7da566e7f2 test(Tabs): consistent items with playground 2024-04-25 11:26:52 +02:00
Benjamin Canac
f0627f700e test: update snapshots with latest icons 2024-04-25 11:21:44 +02:00
plushdohn
c6a93f71f2 fix: dynamic slots autocomplete (#77)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-04-24 19:15:20 +02:00
Benjamin Canac
6d377d1f4b fix: remove IconProps usage 2024-04-24 17:38:42 +02:00
Benjamin Canac
f9259f6857 fix(Input): missing file: selector on dark mode 2024-04-24 16:25:09 +02:00
Benjamin Canac
142affb9a7 feat(Icon): use @antfu/nuxt-icon-poc (#76)
Co-authored-by: Anthony Fu <anthonyfu117@hotmail.com>
2024-04-24 14:10:54 +02:00
Benjamin Canac
a44a24962b chore(vscode): enable eslint flat config 2024-04-24 11:14:40 +02:00
Benjamin Canac
0424405ff6 chore(deps): update 2024-04-23 11:53:53 +02:00
Benjamin Canac
f076019f8f feat(useKbd): new composable (#73) 2024-04-23 11:52:09 +02:00
Benjamin Canac
89ff6b6702 feat(useToast): add clear method 2024-04-22 17:15:29 +02:00
Silver343
814437255e feat(RadioGroup): handle horizontal orientation (#74) 2024-04-22 14:14:51 +02:00
Benjamin Canac
e1ab903109 fix(templates): unshift css 2024-04-18 18:02:16 +02:00
Benjamin Canac
54060f686c chore(eslint): use overrideRules 2024-04-18 16:27:01 +02:00
Sylvain Marroufin
80b413a724 feat(defineShortcuts): migrate with reactivity (#72) 2024-04-18 15:51:43 +02:00
Benjamin Canac
ae2aaa9d1a test: type options slots 2024-04-18 12:55:10 +02:00
Benjamin Canac
76e3d0b9f3 fix(Link): add missing slots definition 2024-04-18 12:54:47 +02:00
Benjamin Canac
dc6f830785 cli: add --pro and --primitive options 2024-04-18 12:36:42 +02:00
Benjamin Canac
be53873c1a cli: export in files as nuxtui 2024-04-18 12:17:21 +02:00
Benjamin Canac
69539a62b4 cli: sort files 2024-04-18 11:46:01 +02:00
Benjamin Canac
30debff9cb chore(pnpm): migrate to 9.0 2024-04-17 17:25:52 +02:00
Benjamin Canac
3cbcc0f09a docs: clean content components 2024-04-17 16:27:27 +02:00
Benjamin Canac
1b941ede36 chore(Switch): remove useless peer class 2024-04-17 16:24:05 +02:00
Benjamin Canac
3c89d6b2c5 fix(Checkbox): reduce icon size 2024-04-17 16:23:54 +02:00
Benjamin Canac
fc3d42d5ea feat(Accordion): add trailingIcon prop 2024-04-17 16:14:47 +02:00
Benjamin Canac
c36bae4b21 feat(Pagination): new component
Resolves #11
2024-04-17 16:14:24 +02:00
Benjamin Canac
7d736c3812 test(Alert): use primary color with variant 2024-04-17 15:44:35 +02:00
Benjamin Canac
d3c79912d8 fix(RadioGroup): missing as prop binding 2024-04-17 13:00:11 +02:00
Benjamin Canac
3e7665626e chore(deps): update 2024-04-17 12:54:24 +02:00
Benjamin Canac
b4a736d668 chore(package): bump version to 3.0.0 2024-04-17 12:52:34 +02:00
Benjamin Canac
1dcc1f5074 feat(DropdownMenu): add #item slot for consistency 2024-04-17 12:19:20 +02:00
Benjamin Canac
ea19a3061f feat(NavigationMenu): rename links to items + improve slots 2024-04-17 12:19:20 +02:00
Benjamin Canac
d56d3a13e3 feat(Breadcrumb): rename links to items + improve slots 2024-04-17 12:19:20 +02:00
Benjamin Canac
6f88f355fa chore(Tooltip): remove useless slots 2024-04-17 12:19:20 +02:00
Benjamin Canac
e54dd55053 chore(Tabs): move #default slot around trigger 2024-04-17 12:19:20 +02:00
Benjamin Canac
0f69f2bd4b chore(Accordion): move #default slot around trigger 2024-04-17 12:19:05 +02:00
Benjamin Canac
ab83053fef fix(Container): missing slots definition 2024-04-17 11:58:26 +02:00
Benjamin Canac
02da03b4a8 fix(Card): missing slots definition 2024-04-17 11:58:13 +02:00
Benjamin Canac
3651c7ec41 fix(Input): wrong type for type prop 2024-04-17 11:57:43 +02:00
Benjamin Canac
83049fd23e fix(Toast): prevent progress bar to blink on leave 2024-04-16 18:41:58 +02:00
Benjamin Canac
7aa353d8cc chore(Alert): update ring on white color 2024-04-16 17:42:47 +02:00
Benjamin Canac
7154d96e10 playground(navigation-menu): improve container 2024-04-16 17:28:35 +02:00
Benjamin Canac
0f10d98820 feat(NavigationMenu): pass index to slots 2024-04-16 17:28:18 +02:00
Benjamin Canac
735f81e771 feat(DropdownMenu): pass index to slots 2024-04-16 17:27:12 +02:00
Benjamin Canac
b78ca9c56a fix(Tabs): add missing slots definition 2024-04-16 17:24:57 +02:00
Benjamin Canac
13a53f4cfb chore: use gap instead of gap-x for consistency 2024-04-16 17:24:41 +02:00
Benjamin Canac
53a2bc0264 feat(Breadcrumb): new component
Resolves #22
2024-04-16 17:23:41 +02:00
Benjamin Canac
298ac68447 fix(NavigationMenu): handle truncate on vertical orientation 2024-04-16 17:09:17 +02:00
Benjamin Canac
f302a15972 feat: uniformize components sizes (#68) 2024-04-16 12:26:29 +02:00
Romain Hamel
78e45600de feat(Slider): new component (#57)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-04-15 16:15:29 +02:00
Benjamin Canac
820417956e playground: add bg for scale drawer now that navigation menu has isolate 2024-04-15 15:21:47 +02:00
Benjamin Canac
f664f69097 fix(NavigationMenu): handle disabled through variants + isolate list + use separator instead of divide 2024-04-15 15:21:25 +02:00
Benjamin Canac
cd214f91db fix(DropdownMenu): handle disabled with data attribute for links 2024-04-15 14:48:33 +02:00
Benjamin Canac
6236953ed0 fix(Accordion): handle disabled through variants 2024-04-15 14:43:56 +02:00
Benjamin Canac
6ce70b768b test(Checkbox): update snapshots 2024-04-15 14:23:05 +02:00
Benjamin Canac
d92022fb8d playground(textarea): clean 2024-04-15 14:22:58 +02:00
Benjamin Canac
1e65933d9c fix(Tabs): horizontal orientation 2024-04-15 14:22:49 +02:00
Romain Hamel
84847965af chore(Checkbox/Switch): change model binding (#58)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-04-15 13:37:18 +02:00
Romain Hamel
2fe91f3847 feat(Switch): add label and description props (#60)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-04-15 11:56:30 +02:00
Benjamin Canac
1535313596 feat(Alert): new component
Resolves #23
2024-04-12 19:00:55 +02:00
Benjamin Canac
514d17048f chore(Toast): update slots 2024-04-12 18:59:53 +02:00
Benjamin Canac
48ddf39188 fix(Tabs): specific transition 2024-04-12 18:38:58 +02:00
Benjamin Canac
c83054bd73 test(Input): update snapshots 2024-04-12 18:37:59 +02:00
Benjamin Canac
cbd58ee707 chore(Toast): improve progress bar 2024-04-12 18:37:32 +02:00
Benjamin Canac
239e0a5ac1 fix(Toaster): add missing transition on translate 2024-04-12 18:27:12 +02:00
Benjamin Canac
a72649f3c9 chore: remove will-change classes 2024-04-12 18:26:41 +02:00
Benjamin Canac
af52fde119 playground(badge): iterate over variants 2024-04-12 18:24:51 +02:00
Benjamin Canac
1d2e1caaf5 feat(Button): add subtle variant 2024-04-12 18:24:31 +02:00
Benjamin Canac
9a42338da3 feat(Toast): actions color defaults from prop 2024-04-12 15:28:17 +02:00
Benjamin Canac
cfb4cfdd7b fix(Toast): add missing slots 2024-04-12 15:26:58 +02:00
Benjamin Canac
a31d4cffb5 fix(Input): use pl / pr instead of ps / pe
Resolves #32
2024-04-12 14:50:32 +02:00
Benjamin Canac
557bdb7297 test: update snapshots 2024-04-12 14:03:25 +02:00
Benjamin Canac
abb7580f71 chore(module): lint 2024-04-12 14:02:23 +02:00
Benjamin Canac
74a640ceca chore(theme): lint 2024-04-12 14:01:23 +02:00
Benjamin Canac
290e4ce150 test: lint 2024-04-12 14:00:58 +02:00
Benjamin Canac
9993b6727a modules: lint 2024-04-12 14:00:18 +02:00
Benjamin Canac
a5e06a3960 scripts: lint 2024-04-12 14:00:13 +02:00
Benjamin Canac
9529f8c1dd cli: lint 2024-04-12 14:00:05 +02:00
Benjamin Canac
02d55b0edb playground: lint 2024-04-12 14:00:00 +02:00
Benjamin Canac
786ee8e7e2 chore(deps): update eslint 2024-04-12 13:59:25 +02:00
Benjamin Canac
be49abb2cd chore(deps): update 2024-04-12 12:21:01 +02:00
Benjamin Canac
c3ed18beb6 fix(Toaster): wrong leave animation when collapsed 2024-04-11 16:03:50 +02:00
Benjamin Canac
4dcb74e0a9 fix(Toaster): increase container height to prevent animation blink 2024-04-11 15:40:57 +02:00
Benjamin Canac
d726e4ddac feat(Toast): implement progress duration
Resolves #51
2024-04-11 15:40:37 +02:00
Benjamin Canac
7350e8e46b chore(deps): update 2024-04-11 15:31:32 +02:00
Benjamin Canac
5e6275fcff feat(Drawer): implement with vaul-vue
Resolves #53
2024-04-11 14:50:38 +02:00
Benjamin Canac
bc2d9ab620 chore(Slideover): remove header div when unnecessary 2024-04-11 14:41:59 +02:00
Benjamin Canac
2a2e3953cb chore(Modal): remove header div when unnecessary 2024-04-11 14:41:54 +02:00
Benjamin Canac
d15c8c21da test(Slideover): add test without close 2024-04-11 14:41:12 +02:00
Benjamin Canac
a8c1340fa7 test(Modal): add test without close 2024-04-11 14:41:00 +02:00
Benjamin Canac
432256dc67 chore(Toaster): move slot first 2024-04-11 14:39:57 +02:00
Benjamin Canac
74feb3a8cb test(Toast): update 2024-04-11 11:41:29 +02:00
Benjamin Canac
3611f07d93 test(Tooltip): wrap with TooltipProvider instead of UApp 2024-04-11 11:29:08 +02:00
Benjamin Canac
4b29828e9d fix(Toaster): proxy slot from App 2024-04-11 11:25:38 +02:00
Benjamin Canac
a391c60aa0 test: update snapshots 2024-04-10 18:40:35 +02:00
Sandro Circi
8d76a8b195 feat(Separator): new component (#46)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-04-10 18:40:08 +02:00
Benjamin Canac
78d5b32fd3 chore(Toast): lint 2024-04-10 18:27:01 +02:00
Benjamin Canac
46d6545eb3 chore(deps): revert eslint 2024-04-10 18:25:27 +02:00
Benjamin Canac
3da1e1a518 feat(Toast): new component (#50) 2024-04-10 18:22:09 +02:00
Benjamin Canac
90f18a3505 chore(deps): update 2024-04-10 17:38:45 +02:00
Benjamin Canac
80a8c2d772 fix(DropdownMenu): add overflow scroll if height is added 2024-04-10 17:38:10 +02:00
Benjamin Canac
bde7a30a73 chore(radio-group): clean theme 2024-04-10 17:37:51 +02:00
Benjamin Canac
bf0a04eb8b feat(Tabs): handle avatar 2024-04-09 18:19:17 +02:00
Benjamin Canac
d43c29b4df chore(templates): revert specific accordion and collapsible animations 2024-04-08 17:24:47 +02:00
Benjamin Canac
d545a927a1 chore(Switch): clean 2024-04-08 17:20:01 +02:00
Benjamin Canac
c0ab0cdde0 chore(DropdownMenu): add comment on type 2024-04-08 17:19:44 +02:00
Benjamin Canac
2a524b1772 chore(deps): update 2024-04-08 13:52:27 +02:00
Romain Hamel
ebb7c074af feat(Switch): form integration (#48)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-04-08 12:15:18 +02:00
Romain Hamel
2dfaea580a chore(Form): export FormValidationException in #ui/types (#47) 2024-04-08 12:00:38 +02:00
Benjamin Canac
bb42594ea4 test: update snapshots 2024-04-05 17:14:49 +02:00
Benjamin Canac
2cc41dedcf feat(Kbd): add color prop 2024-04-05 17:14:39 +02:00
Benjamin Canac
06ea029ef6 feat(Tabs): handle items icon 2024-04-05 17:14:23 +02:00
Benjamin Canac
78613d8811 chore(deps): update tailwindcss 2024-04-05 11:27:39 +02:00
Benjamin Canac
35596fbdbf chore(deps): update 2024-04-05 11:22:29 +02:00
Benjamin Canac
58a29911dd chore(NavigationMenu): add missing value on items 2024-04-04 18:22:57 +02:00
Benjamin Canac
92e1d09990 fix(Tabs): use transition-all 2024-04-04 18:22:46 +02:00
Benjamin Canac
774858187e playground(popover): add all sides for click mode 2024-04-04 15:14:10 +02:00
Benjamin Canac
b43fff6b07 chore(deps): update 2024-04-04 15:14:10 +02:00
Benjamin Canac
b712a2c31c chore(FormField): clean container class 2024-04-04 15:14:10 +02:00
Benjamin Canac
b99482913e chore(Slideover): use variants to type side prop 2024-04-04 12:09:32 +02:00
Benjamin Canac
bc85d70924 chore(DropdownMenu): move slots type to parent 2024-04-04 12:07:59 +02:00
Benjamin Canac
e360ab3084 chore(cli): clean 2024-04-04 12:04:16 +02:00
Benjamin Canac
39cd67a5e3 playground(app): update body colors 2024-04-03 18:36:31 +02:00
Benjamin Canac
61851f838b chore(module): rename plugin to colors 2024-04-03 18:36:21 +02:00
Benjamin Canac
7caeb0a635 chore(icons): move to theme 2024-04-03 18:36:10 +02:00
Benjamin Canac
4a409fdf8b chore(collapsible/accordion): merge animations 2024-04-03 18:12:05 +02:00
Benjamin Canac
ea29cc238c chore: allow as in content and arrow props 2024-04-03 17:52:08 +02:00
Benjamin Canac
56da54b440 chore(Tabs): add content prop with force-mount 2024-04-03 17:51:26 +02:00
Benjamin Canac
550c89d92c chore(Accordion): add content prop for consistency 2024-04-03 17:50:54 +02:00
Benjamin Canac
c36940a221 fix(Accordion): dont set a default-value 2024-04-03 17:50:32 +02:00
Benjamin Canac
5f2a9ddc2e chore: move animations in tailwind.css
Resolves #25
2024-04-03 17:08:16 +02:00
Benjamin Canac
17c7256864 chore(theme): use kebab case 2024-04-02 19:29:35 +02:00
Benjamin Canac
659c58b49f chore(Provider): rename to App 2024-04-02 19:01:07 +02:00
Benjamin Canac
47e32a13ca chore(module): type icons from app config 2024-04-02 18:27:15 +02:00
Benjamin Canac
0b29cf5aa3 playground: clean nuxt config 2024-04-02 17:22:19 +02:00
Benjamin Canac
f3c690ebd8 chore(templates): move DeepPartial to runtime types
chore(templates): up
2024-04-02 17:22:19 +02:00
Benjamin Canac
ab9fc3eebb cli: export bin 2024-04-02 16:43:40 +02:00
Benjamin Canac
54aa892bf0 chore(module): update addTemplates export 2024-04-02 16:03:46 +02:00
Benjamin Canac
48fc683831 chore(deps): update 2024-04-02 12:46:16 +02:00
Benjamin Canac
2fb2a507b4 chore(package): add build script 2024-04-02 12:43:27 +02:00
Romain Hamel
e29b514f8d feat(RadioGroup): new component (#41)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-04-02 11:35:16 +02:00
Benjamin Canac
80a3a0c28f fix(Tabs): broken design 2024-03-29 18:13:43 +01:00
Benjamin Canac
864cd83520 chore(cli): export component types 2024-03-29 18:07:07 +01:00
Benjamin Canac
cff37bf211 feat(Avatar): bind as to image to support NuxtImg 2024-03-29 16:59:43 +01:00
Benjamin Canac
b471547eb7 chore(components): improve imports 2024-03-29 16:59:24 +01:00
Benjamin Canac
10b56bb16c chore(useShortcuts): prevent double export 2024-03-29 16:25:02 +01:00
Benjamin Canac
74cfb3d18f chore(types): export from components 2024-03-29 16:24:40 +01:00
Benjamin Canac
8234bc6a15 playground(app): remove container 2024-03-29 14:52:43 +01:00
Benjamin Canac
5fcd6d1bea chore(theme): improve focus 2024-03-29 14:45:47 +01:00
Benjamin Canac
44033508a7 feat(DropdownMenu): new component (#37) 2024-03-29 13:42:02 +01:00
Benjamin Canac
2fbf47e1fc chore(NavigationMenu): better indexes 2024-03-27 17:17:39 +01:00
Benjamin Canac
4ba4f9ee6d test: update snapshots 2024-03-27 17:17:17 +01:00
Benjamin Canac
ee1d6ed08f fix(NavigationMenu): label doesn't need to be typed as number 2024-03-27 16:46:32 +01:00
Benjamin Canac
4301821473 fix(NavigationMenu): optional links 2024-03-27 16:45:40 +01:00
Benjamin Canac
20caea1cd7 fix(Tabs): optional items 2024-03-27 16:45:16 +01:00
Benjamin Canac
d00084c54c fix(Tooltip): missing conditions on slots 2024-03-27 16:45:03 +01:00
Benjamin Canac
c060b461e9 chore(deps): pin vite 2024-03-27 15:02:22 +01:00
Benjamin Canac
e8419fac01 Merge remote-tracking branch 'upstream/dev' into dev 2024-03-27 14:41:57 +01:00
Benjamin Canac
36a3279228 chore: update resolutions 2024-03-27 14:37:32 +01:00
Benjamin Canac
508ae0806f chore: remove useless css file 2024-03-27 14:15:35 +01:00
Benjamin Canac
fe4892e030 test: update snapshots 2024-03-27 14:03:07 +01:00
Benjamin Canac
74325441e9 chore(deps): update 2024-03-27 14:03:00 +01:00
Benjamin Canac
1ddca46fa4 playground: remove tailwind.config 2024-03-27 13:58:57 +01:00
Benjamin Canac
85c693e3ba remove old files 2024-03-27 12:39:55 +01:00
Benjamin Canac
f3fec877c5 Merge branch 'main' of https://github.com/benjamincanac/nuxt-ui3 into dev 2024-03-27 12:34:43 +01:00
Romain Hamel
bfd5988358 feat(Checkbox): new component (#67)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-03-27 12:00:15 +01:00
Benjamin Canac
8fd369372b feat(Switch): handle loading and loadingIcon
Resolves #65
2024-03-26 15:48:16 +01:00
Benjamin Canac
c9f09992b7 fix(plugins): use import.meta 2024-03-26 15:26:04 +01:00
Benjamin Canac
01bcca3dd7 chore(Textarea): rename inputRef to textareaRef 2024-03-25 14:26:44 +01:00
Benjamin Canac
8688653bc9 test(Input): improve 2024-03-25 12:05:59 +01:00
Benjamin Canac
b5b3e97f5f test(Button): improve 2024-03-25 12:05:11 +01:00
Benjamin Canac
afc270589c chore(Textarea): clean 2024-03-22 18:30:11 +01:00
Benjamin Canac
03fb75f256 playground(textarea): clean 2024-03-22 18:30:02 +01:00
Benjamin Canac
bed62520a9 fix(Textarea): invalid xs size 2024-03-22 18:29:45 +01:00
Benjamin Canac
d5fe5b3f4d fix(Chip): improve sizes 2024-03-22 18:23:58 +01:00
Benjamin Canac
c726f13ac2 fix(Avatar): improve sizes 2024-03-22 18:23:58 +01:00
Benjamin Canac
3a89661c66 fix(Switch): improve sizes 2024-03-22 18:23:58 +01:00
Romain Hamel
2ca6973337 feat(Textarea): new component (#62)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-03-22 17:53:43 +01:00
Romain Hamel
d23e3e1c76 test(Input): use mount to access defineModel events 2024-03-22 17:38:29 +01:00
Benjamin Canac
4a281b3093 fix(Input): invalid xs size 2024-03-22 17:18:48 +01:00
Benjamin Canac
fbe3a40668 test(Switch): update snapshots 2024-03-22 17:17:53 +01:00
Romain Hamel
091f8e91c4 feat(Input): use defineModel (#61) 2024-03-22 17:14:57 +01:00
Benjamin Canac
cd1073d938 feat(Switch): new component 2024-03-22 15:57:12 +01:00
Benjamin Canac
245e9941c0 test(Input): add sizes 2024-03-22 15:56:57 +01:00
Benjamin Canac
f0f89272a0 fix(Button): invalid icon size for lg 2024-03-22 15:56:45 +01:00
Benjamin Canac
6063d9d1b9 playground(button): add new row without icons 2024-03-22 15:56:33 +01:00
Benjamin Canac
09b5752cd2 chore(module): move back to vite plugin 2024-03-22 14:50:40 +01:00
Benjamin Canac
a057945ca4 playground: simplify with theme 2024-03-22 14:50:22 +01:00
Benjamin Canac
2fefa8ab74 playground(link): improve 2024-03-22 12:49:59 +01:00
Benjamin Canac
4bd0d71875 test: update snapshots 2024-03-22 12:48:06 +01:00
Benjamin Canac
147c452e7e chore(Collapsible): improve styles 2024-03-22 12:47:37 +01:00
Benjamin Canac
77fe06d446 chore(Accordion): improve styles 2024-03-22 12:47:26 +01:00
Benjamin Canac
349780dae1 feat(Link): style with app config 2024-03-22 12:46:52 +01:00
Benjamin Canac
e3ef0c59b9 chore(cli): improve templates 2024-03-22 11:39:52 +01:00
Benjamin Canac
2f200d51f8 chore(deps): update tailwindcss 2024-03-22 10:44:49 +01:00
Benjamin Canac
6946c2dfec playground(collapsible): handle trailingIcon differently 2024-03-21 18:41:28 +01:00
Romain Hamel
167127861f feat(Form): nested form validation (#23)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-03-21 18:39:59 +01:00
Benjamin Canac
f086f2662e fix(Tabs): missing props pick 2024-03-21 17:40:09 +01:00
Benjamin Canac
52eef36baa chore(Accordion): improve and add tests 2024-03-21 17:39:03 +01:00
Benjamin Canac
a03b21fdb8 chore(Input): remove useless slot props 2024-03-21 17:23:49 +01:00
Benjamin Canac
1c1a39bcce chore(Button): remove useless slot props 2024-03-21 17:23:37 +01:00
Benjamin Canac
c8bedf8458 fix(NavigationMenu): use ULink with custom 2024-03-21 17:10:30 +01:00
Benjamin Canac
3ed5a08518 feat(Link): break component in two with custom prop 2024-03-21 17:10:18 +01:00
Benjamin Canac
b2b4804e78 playground: add link 2024-03-21 17:01:24 +01:00
Benjamin Canac
4ba76f5a3f chore(utils): clean 2024-03-21 17:01:11 +01:00
Benjamin Canac
4ae45abd63 chore(Button): remove class on slots 2024-03-21 17:01:11 +01:00
Benjamin Canac
d1aa6e3fd9 chore(NavigationMenu): improve slots 2024-03-21 13:05:44 +01:00
Benjamin Canac
594c835f14 test(Tabs): update snapshots 2024-03-21 13:01:11 +01:00
Benjamin Canac
a21648a191 feat(Accordion): new component 2024-03-21 13:00:58 +01:00
Benjamin Canac
98920e549e chore(theme): add more icons 2024-03-21 13:00:34 +01:00
Benjamin Canac
7e1196c62c chore(Tooltip): improve slots 2024-03-21 12:55:49 +01:00
Benjamin Canac
89ab141376 chore: clean withDefaults 2024-03-21 12:55:21 +01:00
Benjamin Canac
f4a1d4a7c3 chore(Tabs): improve slots 2024-03-21 12:54:39 +01:00
Benjamin Canac
2756d35458 chore(Tabs): rename #item slot to #content 2024-03-21 10:44:46 +01:00
Benjamin Canac
5b789a5397 chore(templates): add FIXME for colors type
Related to #59
2024-03-20 17:09:35 +01:00
Benjamin Canac
a7cc288513 chore(deps): update 2024-03-20 14:20:07 +01:00
Benjamin Canac
a78b0965e8 fix(FormField): generics 2024-03-20 14:13:32 +01:00
Benjamin Canac
03edad885d fix(NavigationMenu): prevent err without links 2024-03-20 14:08:40 +01:00
Benjamin Canac
de8100af3a feat(Input): handle icons 2024-03-20 14:04:26 +01:00
Benjamin Canac
418ffb8426 test: update 2024-03-20 14:03:33 +01:00
Benjamin Canac
6e10a0942f feat(Button): use useComponentIcons 2024-03-20 12:43:27 +01:00
Benjamin Canac
e4882e6804 feat(useComponentIcons): extract repetitive logic 2024-03-20 12:43:07 +01:00
Benjamin Canac
bef0e38344 chore(useFormField): use function 2024-03-20 12:34:58 +01:00
Benjamin Canac
802a15990d fix(Link): improve type prop 2024-03-20 12:34:44 +01:00
Benjamin Canac
68f3da8816 playground: add padding bottom 2024-03-20 12:34:24 +01:00
Benjamin Canac
0d4d86d79d feat(NavigationMenu): new component 2024-03-19 19:12:31 +01:00
Benjamin Canac
5a2a31092a chore(Popover): remove useless props 2024-03-19 18:37:15 +01:00
Benjamin Canac
46c066d791 fix(Link)!: expose active instead of isActive in default slot 2024-03-19 18:37:00 +01:00
Benjamin Canac
aaf2a2d8ad chore(components): consistent slots declaration 2024-03-19 18:35:27 +01:00
Benjamin Canac
6cd7c8a5fb fix(Badge): handle label as number 2024-03-19 18:35:01 +01:00
Benjamin Canac
961e6af9c8 chore(components): improve imports 2024-03-19 18:34:50 +01:00
Benjamin Canac
0920099362 fix(Input): use ring instead of ring-1 2024-03-19 18:34:11 +01:00
Benjamin Canac
f8b50a3571 fix(Tabs): use shrink-0 2024-03-19 18:33:49 +01:00
Benjamin Canac
cf91171f6c chore(Tooltip): add tests 2024-03-19 16:18:24 +01:00
Romain Hamel
de62676647 feat(Form): new component (#4)
Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-03-19 16:09:12 +01:00
Benjamin Canac
1cec712fb8 cli: use camelCase for theme 2024-03-19 14:21:30 +01:00
Benjamin Canac
f46f8327c4 cli: wrong case 2024-03-19 10:44:56 +01:00
Benjamin Canac
0a33db835c test: update snapshots 2024-03-18 22:55:35 +01:00
Benjamin Canac
1976ecef17 chore(deps): update nuxt 2024-03-18 22:54:30 +01:00
Benjamin Canac
2f09d1915f playground(popover): improve 2024-03-18 22:05:25 +01:00
Benjamin Canac
0c0ff7b100 playground(tooltip): improve 2024-03-18 22:05:17 +01:00
Benjamin Canac
fe467da9bf fix(Avatar): increase gray on light mode 2024-03-18 22:05:07 +01:00
Benjamin Canac
3cdbb27635 fix(Skeleton): increase gray on light mode 2024-03-18 22:05:00 +01:00
Benjamin Canac
9254f3972b chore(Slideover): clean theme 2024-03-18 22:04:50 +01:00
Benjamin Canac
3e8a99244e feat(Slideover): add top / bottom sides 2024-03-18 21:36:05 +01:00
Benjamin Canac
da9ea7ac17 chore(Slideover): add size to close button 2024-03-18 21:34:56 +01:00
Benjamin Canac
a9188d870a chore(Modal): add size to close button 2024-03-18 21:34:43 +01:00
Benjamin Canac
81cbd2a1d6 playground(card): clean 2024-03-18 21:34:31 +01:00
Benjamin Canac
cdf6ebdafb fix(module): use @tailwindcss/postcss 2024-03-18 21:34:22 +01:00
Benjamin Canac
38eb932b53 feat(Slideover): new component 2024-03-18 17:19:06 +01:00
Benjamin Canac
a7cb28a50e chore(Card): improve spacing 2024-03-18 17:18:45 +01:00
Benjamin Canac
73880f798d chore(Modal): improve spacing 2024-03-18 17:18:35 +01:00
Benjamin Canac
d73a16f551 chore(deps): update 2024-03-18 17:17:30 +01:00
Benjamin Canac
5d76539f3c playground(modal): update 2024-03-18 15:51:00 +01:00
Benjamin Canac
5d1d5b33e8 feat(Modal): new component 2024-03-18 15:30:57 +01:00
Benjamin Canac
ec95ae664d chore(Tooltip): improve v-bind 2024-03-18 15:30:38 +01:00
Benjamin Canac
35a50ae60d chore(Link): clean 2024-03-18 15:30:28 +01:00
Benjamin Canac
7ff5cba9be chore(Button): clean 2024-03-18 15:30:22 +01:00
Benjamin Canac
fa2f752053 test: update snapshots 2024-03-18 11:35:52 +01:00
Benjamin Canac
cecfb58445 fix(Card): improve body padding 2024-03-18 11:33:24 +01:00
Benjamin Canac
d2949310ee fix(Tabs): force-mount content 2024-03-18 11:32:37 +01:00
Benjamin Canac
c85a8cfe0b fix(Collapsible): ensure default slot exists 2024-03-18 11:32:22 +01:00
Benjamin Canac
5d3ad6b93e fix(Popover): ensure default slot exists 2024-03-18 11:32:10 +01:00
Benjamin Canac
431255e0fe fix(Tooltip): ensure default slot exists 2024-03-18 11:31:59 +01:00
Benjamin Canac
6dfd696092 fix(Chip): extend now works with compound variants 2024-03-18 11:31:35 +01:00
Benjamin Canac
53755da835 fix(Button): extend now works with compound variants 2024-03-18 11:31:29 +01:00
Benjamin Canac
a12ccbc052 playground(collapsible): use placeholder component 2024-03-18 11:31:04 +01:00
Benjamin Canac
f5c0259961 chore(deps): update 2024-03-18 11:30:50 +01:00
Benjamin Canac
25300a10c8 chore(.npmrc): add 2024-03-18 11:30:42 +01:00
Benjamin Canac
73977e6d19 playground(card): add page 2024-03-14 18:29:26 +01:00
Benjamin Canac
63f752a4a8 fix(plugins): add missing type 2024-03-14 18:29:13 +01:00
Benjamin Canac
138eabda6b chore(module): delay templates 2024-03-14 15:30:33 +01:00
Benjamin Canac
13d389fd39 feat(Tabs): new component 2024-03-14 15:20:35 +01:00
Benjamin Canac
6e42ee1e2a chore(deps): bump @vue/test-utils and happy-dom 2024-03-14 15:08:25 +01:00
Benjamin Canac
a86dc836b8 chore(deps): bump tailwindcss 2024-03-14 14:45:46 +01:00
Benjamin Canac
6c5354edde fix(Tooltip): remove content max-width 2024-03-14 11:19:17 +01:00
Benjamin Canac
e5af5aeb34 playground(popover): add lang ts 2024-03-14 11:18:15 +01:00
Benjamin Canac
870d8c1cd6 playground(collapsible): improve transition 2024-03-14 11:18:00 +01:00
Benjamin Canac
cdd9b178f3 feat(cli): init command 2024-03-13 17:03:28 +01:00
Benjamin Canac
9a42fa415f chore: add eol 2024-03-13 16:58:11 +01:00
Benjamin Canac
34d6e18638 chore(editorconfig): add 2024-03-13 16:55:06 +01:00
Benjamin Canac
0a00387688 fix(templates): handle - in regexp 2024-03-13 14:43:20 +01:00
Benjamin Canac
ebbd931db1 playground(popover): update 2024-03-13 14:43:07 +01:00
Benjamin Canac
7d2d3b9c0f fix(Popover): split reactive props with mode 2024-03-13 14:42:58 +01:00
Benjamin Canac
d6bebd5ef9 feat(Chip): new component 2024-03-13 14:42:39 +01:00
Benjamin Canac
e07088068f playground(collapsible): use #trailing slot 2024-03-13 12:27:24 +01:00
Benjamin Canac
959b1295f2 test: update 2024-03-13 12:27:10 +01:00
Benjamin Canac
4d3bab71e5 chore(components): use Primitive where possible 2024-03-13 12:27:01 +01:00
Benjamin Canac
c4419fa113 fix(module): prevent colors option merge 2024-03-12 18:24:02 +01:00
Benjamin Canac
e2fb25309f feat(Skeleton): new component 2024-03-12 18:22:55 +01:00
Benjamin Canac
4b3a9855ac chore(Popover): mode doc 2024-03-12 17:28:46 +01:00
Benjamin Canac
2d340d2054 playground(tooltip): avatar trigger 2024-03-12 17:28:02 +01:00
Benjamin Canac
7b8960124f feat(Popover): handle hover mode 2024-03-12 17:20:32 +01:00
Benjamin Canac
78908c3d64 feat(Card): new component 2024-03-12 16:07:46 +01:00
Benjamin Canac
69b281c408 test(Collapsible): add 2024-03-12 16:07:36 +01:00
Benjamin Canac
bc2dba5d71 chore(templates): add base styles 2024-03-12 15:42:14 +01:00
Benjamin Canac
c131ce955f feat(Popover): new 2024-03-12 15:42:07 +01:00
Benjamin Canac
c384ec94a2 fix(Link): active class 2024-03-12 15:38:51 +01:00
Benjamin Canac
0e0c708883 chore(Tooltip): update 2024-03-12 15:38:31 +01:00
Benjamin Canac
a026ae176e chore(Button): put back disabled on loading 2024-03-12 14:58:52 +01:00
Benjamin Canac
93aefaefd3 chore(Button): add issue link 2024-03-12 14:58:36 +01:00
Benjamin Canac
c8bdb51f68 fix(Button): loading on trailing 2024-03-12 14:58:17 +01:00
Daniel Roe
4446531d04 chore: add local module for better development dx (#2)
* chore: add local module for better dx developing nuxt/ui

* up

* up

* up

* feat(Kbd): new

* chore(Badge): update

* chore(Collapsible): remove content prop

* chore(Container): clean

* chore(Avatar): update root bg

* chore(Link): clean

* feat(Tooltip): handle shortcuts

* playground(collapsible): update

---------

Co-authored-by: Benjamin Canac <canacb1@gmail.com>
2024-03-12 12:12:17 +01:00
Benjamin Canac
44d0ceccba playground(avatar): wrong prop 2024-03-11 21:58:07 +01:00
Benjamin Canac
194b451467 chore(deps): update tailwindcss 2024-03-11 21:57:58 +01:00
Benjamin Canac
158f0d2646 chore(Provider): add props 2024-03-11 18:43:23 +01:00
Benjamin Canac
cd5b23a1f6 chore(Tooltip): update props 2024-03-11 18:43:13 +01:00
Benjamin Canac
55c47288a5 chore(Tooltip): keyframes in snake case 2024-03-11 17:40:15 +01:00
Benjamin Canac
37c14186a0 test(Tooltip): add skip 2024-03-11 17:39:40 +01:00
Benjamin Canac
f547db3535 test: clean snapshots 2024-03-11 17:39:23 +01:00
Benjamin Canac
d0c7b8fad3 chore(Button): update 2024-03-11 17:39:05 +01:00
Benjamin Canac
83f311a004 chore(Collapsible): update 2024-03-11 17:38:56 +01:00
Benjamin Canac
037a2fc8fa chore(Avatar): use text prop to prevent breaking change 2024-03-11 17:38:42 +01:00
Benjamin Canac
bc2dbbbbd0 chore(test): add setup 2024-03-11 16:51:17 +01:00
Benjamin Canac
924551e546 test(Avatar): update 2024-03-11 15:43:44 +01:00
Benjamin Canac
78fc16aa18 playground: update 2024-03-11 15:14:53 +01:00
Benjamin Canac
82cb00ce52 test: update 2024-03-11 15:14:40 +01:00
Benjamin Canac
aaedabda3b playground: update 2024-03-11 15:08:54 +01:00
Benjamin Canac
4f344437e2 chore(icons): sort 2024-03-11 15:08:54 +01:00
Benjamin Canac
ef43eb406b chore(theme): use size 2024-03-11 15:08:54 +01:00
Benjamin Canac
b41de5b6dc chroe(components): clean imports 2024-03-11 15:08:54 +01:00
Benjamin Canac
978595ce88 feat(Avatar): new component 2024-03-11 15:08:54 +01:00
zernonia
7823139a35 chore: bump radix version 2024-03-11 20:22:17 +08:00
Benjamin Canac
6765eed733 chore(deps): update tailwindcss 2024-03-10 22:16:03 +01:00
Benjamin Canac
2297fc1479 chore: rename ring-1 to ring 2024-03-10 22:15:30 +01:00
Benjamin Canac
f89cf66efc chore(tsconfig): add exclude 2024-03-09 23:15:16 +01:00
Benjamin Canac
c49521ca6e test(Button): update snapshots 2024-03-09 23:14:57 +01:00
Benjamin Canac
312a177ba8 playground: update 2024-03-09 20:29:24 +01:00
Benjamin Canac
e151be4734 fix(templates): dont override AppConfig type 2024-03-09 20:29:19 +01:00
Benjamin Canac
f9cc5e4f8e playground: update button 2024-03-09 19:59:33 +01:00
Benjamin Canac
31da519650 chore(Tooltip): update 2024-03-09 19:59:15 +01:00
Benjamin Canac
7479270c41 chore(Link): update 2024-03-09 19:59:05 +01:00
Benjamin Canac
1cbce7f2f2 chore(Container): update 2024-03-09 19:58:58 +01:00
Benjamin Canac
2288400eca chore(Collapsible): update 2024-03-09 19:58:52 +01:00
Benjamin Canac
1ccd14ee0e chore(Button): update 2024-03-09 19:58:44 +01:00
Benjamin Canac
2f631845c3 chore(Badge): update 2024-03-09 19:58:35 +01:00
Benjamin Canac
4b75ec265b chore(eslint): disable vue/require-default-prop 2024-03-09 19:09:16 +01:00
Benjamin Canac
320821984d playground: disable devtools 2024-03-09 19:09:01 +01:00
Benjamin Canac
39b879c972 playground: update 2024-03-09 17:16:38 +01:00
Benjamin Canac
e3874e0dd0 chore(deps): update 2024-03-09 16:48:08 +01:00
Benjamin Canac
c10737c0c6 playground: update 2024-03-09 16:35:59 +01:00
Benjamin Canac
7b3d6636f4 chore(Tooltip): update 2024-03-09 16:35:24 +01:00
Benjamin Canac
c6381c183c chore(Link): update 2024-03-09 16:35:16 +01:00
Benjamin Canac
2f65c2eeca chore(Button): dont disable on loading 2024-03-09 16:35:08 +01:00
Benjamin Canac
6edc0cf27b chore(Container): update 2024-03-09 16:34:46 +01:00
Benjamin Canac
bcde20ce3e chore(Collapsible): update 2024-03-09 16:34:36 +01:00
Benjamin Canac
c65a623151 chore(Badge): add 2024-03-09 16:34:20 +01:00
Benjamin Canac
b0222e5531 chore(Tooltip): update 2024-03-08 12:44:50 +01:00
Benjamin Canac
361e47b03c chore(Collapsible): new component 2024-03-08 12:44:43 +01:00
Benjamin Canac
622d582426 chore(Button): update 2024-03-07 23:33:24 +01:00
Benjamin Canac
9592ca9f72 chore(Tooltip): update 2024-03-07 23:33:17 +01:00
Benjamin Canac
c3903f0da1 playground: update 2024-03-07 18:26:21 +01:00
Benjamin Canac
58ce6e86d0 chore(module): update 2024-03-07 18:26:07 +01:00
Benjamin Canac
11dd34c15d chore(templates): handle icons and without function 2024-03-07 17:10:27 +01:00
Benjamin Canac
b08d2bd3c6 chore(module): update 2024-03-07 16:57:14 +01:00
Benjamin Canac
46e27304e8 playground: clean config 2024-03-07 16:57:09 +01:00
Benjamin Canac
c3db2499e7 chore(deps): update 2024-03-07 16:56:59 +01:00
Benjamin Canac
075eee860d playground: update 2024-03-07 16:09:00 +01:00
Benjamin Canac
7e19c30f80 chore(module): update 2024-03-07 16:08:48 +01:00
Benjamin Canac
c79e6f188d chore(module): update theming 2024-03-07 15:33:53 +01:00
Benjamin Canac
0d1e17ef74 playground: update 2024-03-07 13:03:21 +01:00
Benjamin Canac
842acdf4b3 chore(theme): update 2024-03-07 12:56:17 +01:00
Benjamin Canac
9711b4db5e chore(Provider): add 2024-03-07 12:56:09 +01:00
Benjamin Canac
a861961724 chore(Tooltip): add 2024-03-07 12:56:02 +01:00
Benjamin Canac
05e93387b9 chore(Container): update 2024-03-07 12:55:55 +01:00
Benjamin Canac
c90cea55a7 chore(Button): update 2024-03-07 12:55:18 +01:00
Benjamin Canac
1530e82235 chore(module): update colors 2024-03-07 12:55:00 +01:00
Benjamin Canac
e257a43964 chore(deps): update 2024-03-07 12:54:11 +01:00
Benjamin Canac
6f37f02d8d chore(module): override cool color 2024-03-06 20:20:12 +01:00
Benjamin Canac
22c42c402d playground: update 2024-03-06 20:09:05 +01:00
Benjamin Canac
0d1f8528c8 chore(module): dynamic colors 2024-03-06 20:08:58 +01:00
Benjamin Canac
ce267954e0 chore: use tailwind v4 2024-03-06 19:08:48 +01:00
Benjamin Canac
57c2cc0ef4 chore(Button): use ui prop for slots only 2024-03-06 16:29:03 +01:00
Benjamin Canac
66cf178cc3 chore(Container): remove ui prop 2024-03-06 16:28:12 +01:00
Benjamin Canac
7d29ff2b7a chore(Button): use props instead of $props 2024-03-06 16:04:02 +01:00
Benjamin Canac
5449d2aa5f chore(Container): add component 2024-03-06 16:03:45 +01:00
Benjamin Canac
d95556ebda test: update 2024-03-06 15:37:41 +01:00
Benjamin Canac
d69817a128 chore(Button): use defineSlots 2024-03-06 15:37:02 +01:00
Benjamin Canac
d0c1892a14 chore(Button): improve fallback 2024-03-06 14:52:16 +01:00
Benjamin Canac
e51320bac0 chore(Link): remove useless props object 2024-03-06 14:50:50 +01:00
Benjamin Canac
3c2f5e9733 chore: use type-based prop 2024-03-06 14:36:07 +01:00
Benjamin Canac
beb1bf2f0d chore: add @vueuse/core 2024-03-06 14:35:56 +01:00
Benjamin Canac
38a36f4e48 test(Button): add 2024-03-06 12:40:41 +01:00
Benjamin Canac
b67fddeef8 test: setup 2024-03-06 12:40:34 +01:00
Benjamin Canac
8aefde231a chore: move public in playground 2024-03-06 12:36:45 +01:00
Benjamin Canac
17ea7efd3b chore: externalize theme to type app config 2024-03-06 12:27:14 +01:00
Benjamin Canac
f76ec5a376 chore: transform to module 2024-03-05 19:19:37 +01:00
Benjamin Canac
3c716219cf chore: lint 2024-03-05 18:49:05 +01:00
Benjamin Canac
f5e60a00ba chore: init 2024-03-05 18:45:21 +01:00
1170 changed files with 105908 additions and 34752 deletions

View File

@@ -1,14 +0,0 @@
node_modules
dist
.nuxt
coverage
*.log*
.DS_Store
.code
*.iml
package-lock.json
templates/*
sw.js
# Templates
src/templates

View File

@@ -1,46 +0,0 @@
module.exports = {
root: true,
extends: ['@nuxt/eslint-config'],
rules: {
// General
semi: ['error', 'never'],
quotes: ['error', 'single'],
'comma-dangle': ['error', 'never'],
'comma-spacing': ['error', { before: false, after: true }],
'keyword-spacing': ['error', { before: true, after: true }],
'space-before-function-paren': ['error', 'always'],
'object-curly-spacing': ['error', 'always'],
'arrow-spacing': ['error', { before: true, after: true }],
'key-spacing': ['error', { beforeColon: false, afterColon: true, mode: 'strict' }],
'space-before-blocks': ['error', 'always'],
'space-infix-ops': ['error', { int32Hint: false }],
'no-multi-spaces': ['error', { ignoreEOLComments: true }],
'no-trailing-spaces': ['error'],
// Typescript
'@typescript-eslint/type-annotation-spacing': 'error',
// Vuejs
'vue/multi-word-component-names': 0,
'vue/html-indent': ['error', 2],
'vue/comma-spacing': ['error', { before: false, after: true }],
'vue/script-indent': ['error', 2, { baseIndent: 0 }],
'vue/keyword-spacing': ['error', { before: true, after: true }],
'vue/object-curly-spacing': ['error', 'always'],
'vue/key-spacing': ['error', { beforeColon: false, afterColon: true, mode: 'strict' }],
'vue/arrow-spacing': ['error', { before: true, after: true }],
'vue/array-bracket-spacing': ['error', 'never'],
'vue/block-spacing': ['error', 'always'],
'vue/brace-style': ['error', 'stroustrup', { allowSingleLine: true }],
'vue/space-infix-ops': ['error', { int32Hint: false }],
'vue/max-attributes-per-line': [
'error',
{
singleline: {
max: 5
}
}
],
'vue/padding-line-between-blocks': ['error', 'always']
}
}

View File

@@ -1,6 +1,6 @@
name: "🐛 Bug report"
description: Report a bug to help us improve the module.
labels: ["triage"]
labels: ["triage", "bug"]
body:
- type: markdown
attributes:

74
.github/ISSUE_TEMPLATE/bug-v3.yml vendored Normal file
View File

@@ -0,0 +1,74 @@
name: "🐛 Bug report (v3)"
description: Report a bug to help us improve the module (v3 only).
labels: ["triage", "bug", "v3"]
body:
- type: markdown
attributes:
value: |
> [!IMPORTANT]
> As Nuxt UI v3 is currently in alpha, we recommend thorough testing before using it in production environments. We're actively working on stabilization and welcome feedback from early adopters to improve the library.
- type: markdown
attributes:
value: |
Before reporting a bug, please make sure that you have read through our [v3 documentation](https://ui3.nuxt.dev/) and existing [issues](https://github.com/nuxt/ui/issues?q=is%3Aissue%20is%3Aopen%20sort%3Aupdated-desc%20label%3Av3).
- type: textarea
id: env
attributes:
label: Environment
description: You can use `npx nuxi info` to fill this section
placeholder: |
- Operating System: `Darwin`
- Node Version: `v18.16.0`
- Nuxt Version: `3.7.3`
- CLI Version: `3.8.4`
- Nitro Version: `2.6.3`
- Package Manager: `pnpm@8.7.4`
- Builder: `-`
- User Config: `-`
- Runtime Modules: `-`
- Build Modules: `-`
validations:
required: true
- type: dropdown
id: package
attributes:
label: Is this bug related to Nuxt or Vue?
options:
- Nuxt
- Vue
validations:
required: true
- type: input
id: version
attributes:
label: Version
placeholder: v3.0.0-alpha.x
validations:
required: true
- type: textarea
id: reproduction
attributes:
label: Reproduction
description: Please provide a reproduction link. A minimal [reproduction is required](https://antfu.me/posts/why-reproductions-are-required) unless you are absolutely sure that the issue is obvious and the provided information is enough to understand the problem. If a report is vague (e.g. just a generic error message) and has no reproduction, it will receive a "needs reproduction" label. If no reproduction is provided we might close it.
placeholder: https://github.com/my/reproduction
validations:
required: true
- type: textarea
id: description
attributes:
label: Description
description: A clear and concise description of what the bug is. If you intend to submit a PR for this issue, tell us in the description.
validations:
required: true
- type: textarea
id: additonal
attributes:
label: Additional context
description: If applicable, add any other context or screenshots here.
- type: textarea
id: logs
attributes:
label: Logs
description: |
Optional if provided reproduction. Please try not to insert an image but copy paste the log text.
render: shell-script

View File

@@ -1,11 +1,20 @@
name: "🚀 Feature request"
description: Suggest an idea or enhancement for the module.
labels: ["triage"]
labels: ["triage", "enhancement"]
body:
- type: markdown
attributes:
value: |
Before requesting a feature, please make sure that you have read through our [documentation](https://ui.nuxt.com) and existing [issues](https://github.com/nuxt/ui/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc).
- type: dropdown
id: version
attributes:
label: For what version of Nuxt UI are you suggesting this?
options:
- v2.x
- v3.0.0-alpha.x
validations:
required: true
- type: textarea
id: description
attributes:

View File

@@ -6,6 +6,15 @@ body:
attributes:
value: |
Before asking a question, please make sure that you have read through our [documentation](https://ui.nuxt.com) and existing [issues](https://github.com/nuxt/ui/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc).
- type: dropdown
id: version
attributes:
label: For what version of Nuxt UI are you asking this question?
options:
- v2.x
- v3.0.0-alpha.x
validations:
required: true
- type: textarea
id: description
attributes:

View File

@@ -1,72 +0,0 @@
name: ci-dev
on:
push:
branches:
- dev
pull_request:
branches:
- dev
jobs:
ci:
runs-on: ${{ matrix.os }}
permissions:
contents: read
pull-requests: read
strategy:
matrix:
os: [ubuntu-latest] # macos-latest, windows-latest
node: [20]
env:
NUXT_GITHUB_TOKEN: ${{ secrets.NUXT_GITHUB_TOKEN }}
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Install pnpm
uses: pnpm/action-setup@v4
- name: Install node
uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node }}
cache: pnpm
- name: Filter changes
uses: dorny/paths-filter@v3
id: changes
with:
filters: |
src:
- 'src/**'
- 'package.json'
- 'pnpm-lock.yaml'
- name: Install dependencies
run: pnpm install
- name: Prepare
run: pnpm run dev:prepare
- name: Lint
run: pnpm run lint
- name: Typecheck
run: pnpm run typecheck
- name: Build
run: pnpm run build
- name: Test
run: pnpm run test run
- name: Release Edge
if: github.event_name == 'push' && steps.changes.outputs.src == 'true'
run: ./scripts/release-edge.sh
env:
NODE_AUTH_TOKEN: ${{secrets.NODE_AUTH_TOKEN}}

View File

@@ -1,14 +1,21 @@
name: ci-main
name: ci-v3
on:
push:
branches:
- main
- v3
pull_request:
branches:
- v3
jobs:
ci:
runs-on: ${{ matrix.os }}
permissions:
contents: read
pull-requests: read
strategy:
matrix:
os: [ubuntu-latest] # macos-latest, windows-latest
@@ -36,26 +43,26 @@ jobs:
- name: Prepare
run: pnpm run dev:prepare
- name: Devtools prepare
run: pnpm run devtools:prepare
- name: Lint
run: pnpm run lint
- name: Typecheck
run: pnpm run typecheck
- name: Test
run: pnpm run test
- name: Test (vue)
run: pnpm run test:vue
- name: Build
run: pnpm run build
- name: Test
run: pnpm run test run
- name: Build vue fixture
run: pnpm run test:vue:build
- name: Version Check
id: check
uses: EndBug/version-check@v2
with:
token: ${{ secrets.GITHUB_TOKEN }}
- name: Release
if: github.event_name == 'push' && steps.check.outputs.changed == 'true'
run: ./scripts/release.sh
env:
NODE_AUTH_TOKEN: ${{ secrets.NODE_AUTH_TOKEN }}
- name: Publish
run: pnpx pkg-pr-new publish --compact --no-template --pnpm

40
.gitignore vendored
View File

@@ -1,12 +1,32 @@
node_modules
*.log
.nuxt
nuxt.d.ts
.component-meta/
component-meta.*
# Nuxt dev/build outputs
.output
dist
.DS_Store
.history
.vercel
.idea
.env
.data
.nuxt
.nitro
.cache
dist
# Node dependencies
node_modules
# Logs
logs
*.log
# Misc
.DS_Store
.fleet
.idea
# Local env files
.env
.env.*
!.env.example
playground-vue/auto-imports.d.ts
playground-vue/components.d.ts
playground-vue/tsconfig.app.tsbuildinfo
playground-vue/tsconfig.node.tsbuildinfo

View File

@@ -1 +0,0 @@
typescript.includeWorkspace=true

View File

@@ -3,9 +3,6 @@
"commitMessage": "chore(release): v${version}",
"tagName": "v${version}"
},
"npm": {
"publish": false
},
"github": {
"release": true,
"releaseName": "v${version}",

View File

@@ -1,3 +0,0 @@
{
"prettier.enable": false
}

View File

@@ -1,5 +1,600 @@
# Changelog
## [3.0.0-alpha.10](https://github.com/nuxt/ui/compare/v3.0.0-alpha.9...v3.0.0-alpha.10) (2024-12-09)
### ⚠ BREAKING CHANGES
* **module:** migrate to `reka-ui` (#2448)
* **Form:** resolve async validation in yup & issue directly mutate state (#2702)
### Features
* **Avatar:** add `default` slot for fallback ([b741ef3](https://github.com/nuxt/ui/commit/b741ef3313bb894beaed0eaa7323ee3d951bf935))
* **Calendar:** add `icon` props ([#2778](https://github.com/nuxt/ui/issues/2778)) ([0f64802](https://github.com/nuxt/ui/commit/0f648024e0468d34c1499bb5b5d2ed32e0e7de4f))
* **Calendar:** implement component ([#2618](https://github.com/nuxt/ui/issues/2618)) ([2e9aeb5](https://github.com/nuxt/ui/commit/2e9aeb5f05e94d63ea453c4f07a3e84ee2a02773))
* **ColorPicker:** implement component ([#2670](https://github.com/nuxt/ui/issues/2670)) ([e475b64](https://github.com/nuxt/ui/commit/e475b6438d405e4695ffb19155d456534d16b897))
* **CommandPalette:** add `active` field on items for consistency ([3765537](https://github.com/nuxt/ui/commit/37655377e9675982e2fce422bdd79ea651424548))
* **css:** use `color-scheme` utilities on body ([a2512f6](https://github.com/nuxt/ui/commit/a2512f680dc0df7add48bc17ef3be30d579be782))
* **i18n:** add Dutch locale ([#2728](https://github.com/nuxt/ui/issues/2728)) ([3baddfd](https://github.com/nuxt/ui/commit/3baddfd12186a68cc302f31cf0934cb9cf48060d))
* **i18n:** add Turkish locale ([#2716](https://github.com/nuxt/ui/issues/2716)) ([de8228e](https://github.com/nuxt/ui/commit/de8228e504affd1a57106101f5168a33702d4d53))
* **locale:** add Brazilian Portuguese language ([#2825](https://github.com/nuxt/ui/issues/2825)) ([b7ff7d8](https://github.com/nuxt/ui/commit/b7ff7d8aa63c41cf7afbecaa31824e098ea291af))
* **locale:** add Japanese language ([#2794](https://github.com/nuxt/ui/issues/2794)) ([ecc4755](https://github.com/nuxt/ui/commit/ecc4755a17874e59e06e70307a40dfd3fb3f20a0))
* **locale:** add Portuguese language ([#2855](https://github.com/nuxt/ui/issues/2855)) ([8b5d412](https://github.com/nuxt/ui/commit/8b5d412fd70b14a53cffa9129f5edd8a40e0f2e8))
* **locale:** add Slovak language ([#2821](https://github.com/nuxt/ui/issues/2821)) ([68a10f0](https://github.com/nuxt/ui/commit/68a10f09d5f164f2f5f07e65297e29fa2d939425))
* **locale:** translate Korean ([#2703](https://github.com/nuxt/ui/issues/2703)) ([2cbf83e](https://github.com/nuxt/ui/commit/2cbf83eb8484ad9abebd6ca01ad344918570af5b))
* **module:** migrate to `reka-ui` ([#2448](https://github.com/nuxt/ui/issues/2448)) ([81ac076](https://github.com/nuxt/ui/commit/81ac076219c3d7ef151f641414a0fbeca2da0bdd))
* **NavigationMenu:** handle `item.trailingIcon` display ([4b653ef](https://github.com/nuxt/ui/commit/4b653ef7735d9d2dfea65260433ade05eb3d3bd7))
* **Stepper:** new component ([#2733](https://github.com/nuxt/ui/issues/2733)) ([6484d01](https://github.com/nuxt/ui/commit/6484d010a1eee6f5d86968e4701b945953089b17))
* **Table:** handle `meta.class` on `th` and `td` ([#2790](https://github.com/nuxt/ui/issues/2790)) ([004a577](https://github.com/nuxt/ui/commit/004a5774678da24ccc267e96697c6088c51d5eea))
### Bug Fixes
* **Breadcrumb:** missing `aria-hidden` on presentation items ([a7a1227](https://github.com/nuxt/ui/commit/a7a1227c93110727e24f822fa50b547eb66bb16e)), closes [#2725](https://github.com/nuxt/ui/issues/2725)
* **Calendar:** handle icons in RTL mode ([#2770](https://github.com/nuxt/ui/issues/2770)) ([e7b69b7](https://github.com/nuxt/ui/commit/e7b69b7d6f0ebb3c578b9f58bcddf8ad36e6c6ce))
* **Calendar:** omit `as` / `asChild` props ([9478fc0](https://github.com/nuxt/ui/commit/9478fc076846d4a7fef13e63bdc274cd8d161063))
* **ColorPicker:** handle RTL mode ([#2858](https://github.com/nuxt/ui/issues/2858)) ([f98b91c](https://github.com/nuxt/ui/commit/f98b91c22ae21071a25f69cc8682eb6197a54c5a))
* **CommandPalette:** keep `ignoreFilter` groups at their place ([#2833](https://github.com/nuxt/ui/issues/2833)) ([3b9ca22](https://github.com/nuxt/ui/commit/3b9ca2263de1b936639b1b20ad0baf1cb059fda5))
* **components:** apply class on `trigger` instead of `content` when present ([a6ecef0](https://github.com/nuxt/ui/commit/a6ecef0f0d87a8dff4e4cb9ec507058ec94ed82b)), closes [#2132](https://github.com/nuxt/ui/issues/2132)
* **components:** specify collisionPadding to all menus ([148b024](https://github.com/nuxt/ui/commit/148b02464d47ada421313327585924b17f4e3f2d))
* **ContextMenu:** remove close animation ([#2798](https://github.com/nuxt/ui/issues/2798)) ([ed27222](https://github.com/nuxt/ui/commit/ed2722257a22c770eda811fbad58980bcef9dad5))
* **defineShortcuts:** return `useEventListener` to unregister the listener ([80befc1](https://github.com/nuxt/ui/commit/80befc107c6c6e7ab99dbe12376976babf315158)), closes [#2031](https://github.com/nuxt/ui/issues/2031)
* **devtools:** error with renderer when `colorMode` is disabled ([#2792](https://github.com/nuxt/ui/issues/2792)) ([f06fbaf](https://github.com/nuxt/ui/commit/f06fbafc1e709c7b4e54e2ba40d44c5770685a5d))
* **Form:** resolve async validation in yup & issue directly mutate state ([#2702](https://github.com/nuxt/ui/issues/2702)) ([c9806da](https://github.com/nuxt/ui/commit/c9806da6d850ea50ff8d2f11a1fbc5a43459b71f))
* **icons:** make `loading` icon clockwise ([#2797](https://github.com/nuxt/ui/issues/2797)) ([bc2bcb3](https://github.com/nuxt/ui/commit/bc2bcb30d97e2e873c4c7d535f82a4980cd35b02))
* **Link:** partial query match for Vue ([#2787](https://github.com/nuxt/ui/issues/2787)) ([a6c2205](https://github.com/nuxt/ui/commit/a6c22052e1c70e4ce6b2c7f783667a7f8c6cafa4))
* **locale:** improve German translation ([#2826](https://github.com/nuxt/ui/issues/2826)) ([c440c91](https://github.com/nuxt/ui/commit/c440c91a29fc1acd281a7f9d9b0cf74f5341553d))
* **Modal:** prevent from going out of screen ([b7ba2c7](https://github.com/nuxt/ui/commit/b7ba2c7759485ddb0a8bae589e4b6536ac9b1c96)), closes [#2711](https://github.com/nuxt/ui/issues/2711)
* **NavigationMenu:** wrong badge class ([86f2b48](https://github.com/nuxt/ui/commit/86f2b4856cc6beaf0440795500a5c74f9af04f36)), closes [#2766](https://github.com/nuxt/ui/issues/2766)
* **Progress:** handle `horizontal` animation in RTL mode ([#2723](https://github.com/nuxt/ui/issues/2723)) ([0baa3a0](https://github.com/nuxt/ui/commit/0baa3a06d449ab97093c451bd16215cf83c39447))
* **Stepper:** handle RTL mode ([#2844](https://github.com/nuxt/ui/issues/2844)) ([198d04d](https://github.com/nuxt/ui/commit/198d04de51d16ec7fcaa546370e4f67aa73bfee0))
* **Stepper:** missing import ([816bb69](https://github.com/nuxt/ui/commit/816bb69debdbf83f36c3ed3627985142e62b7dd1))
* **Table:** handle `loading` animation in RTL mode ([#2771](https://github.com/nuxt/ui/issues/2771)) ([b1550d5](https://github.com/nuxt/ui/commit/b1550d58adfeb09977619ad3ff7e776782a89603))
* **Tabs:** prevent hover on disabled ([a938d24](https://github.com/nuxt/ui/commit/a938d24f90431494c2da89411c301a228ab8d3f7))
* **Tabs:** truncate not working ([c1ff978](https://github.com/nuxt/ui/commit/c1ff978370fb343950837b380ccf02a33db53ccb))
* **types:** handle array of strings in AppConfig ([#2854](https://github.com/nuxt/ui/issues/2854)) ([4b241ba](https://github.com/nuxt/ui/commit/4b241ba3c32f4456252768b664488799a8278f0e))
* **useLocale:** update locale import to enable tree shaking ([#2735](https://github.com/nuxt/ui/issues/2735)) ([3bccb67](https://github.com/nuxt/ui/commit/3bccb6782a601e686df5d0ee405d738572f182e1))
## [3.0.0-alpha.9](https://github.com/nuxt/ui/compare/v3.0.0-alpha.8...v3.0.0-alpha.9) (2024-11-19)
### Features
* **cli:** add locale command ([#2586](https://github.com/nuxt/ui/issues/2586)) ([824ba56](https://github.com/nuxt/ui/commit/824ba5629183bc4cd59321213558770db211f6e5))
* **css:** add `--ui-bg-muted` / `--ui-border-muted` variables ([7f6db45](https://github.com/nuxt/ui/commit/7f6db45f1e15ef39cda9b732cb601c552f29570a))
* **Form:** apply transformations ([#2550](https://github.com/nuxt/ui/issues/2550)) ([75c5e87](https://github.com/nuxt/ui/commit/75c5e87724e7abdf0a6751d7a1dbbafb947f373f))
* **FormField:** add `error-pattern` prop ([#2601](https://github.com/nuxt/ui/issues/2601)) ([143612e](https://github.com/nuxt/ui/commit/143612ec737d1c7571398601c3222f2eed37996e))
* **InputMenu/SelectMenu:** add `create-item` prop ([#2472](https://github.com/nuxt/ui/issues/2472)) ([f516d7b](https://github.com/nuxt/ui/commit/f516d7b36da51565f4ab05a4c9cfe5e5b4015124))
* **InputNumber:** implement component ([#2577](https://github.com/nuxt/ui/issues/2577)) ([bd2f077](https://github.com/nuxt/ui/commit/bd2f077fe8e645d5fce8b1eb5a6eb1068b3e8f7c))
* **Link:** allow partial query match for its active state ([#2664](https://github.com/nuxt/ui/issues/2664)) ([7329900](https://github.com/nuxt/ui/commit/7329900ae549430b88567a09cbb585d3cf0a6d32))
* **locale:** add Persian language ([#2682](https://github.com/nuxt/ui/issues/2682)) ([14fb21b](https://github.com/nuxt/ui/commit/14fb21be0034ffc0ba5d213734c00f12e0d6bea8))
* **locale:** add Polish language ([#2678](https://github.com/nuxt/ui/issues/2678)) ([2fc36c8](https://github.com/nuxt/ui/commit/2fc36c878c67967ec91e4f6999575bad45521d44))
* **locale:** add support for Arabic ([#2582](https://github.com/nuxt/ui/issues/2582)) ([602a667](https://github.com/nuxt/ui/commit/602a667343be22b72383ab3cf42f36ec9e135082))
* **locale:** add support for Czech translation ([#2593](https://github.com/nuxt/ui/issues/2593)) ([4889d30](https://github.com/nuxt/ui/commit/4889d30b448296de42e146dc5771738837c31f8c))
* **locale:** add support for Italian ([#2583](https://github.com/nuxt/ui/issues/2583)) ([4fbbb25](https://github.com/nuxt/ui/commit/4fbbb25f68b0b5ee76e50f2da776a74d54acc041))
* **locale:** provide `code` ([#2611](https://github.com/nuxt/ui/issues/2611)) ([8a8b1ee](https://github.com/nuxt/ui/commit/8a8b1ee2e1628bc5439ef109d3c68b69bf631f81))
* **locale:** provide `dir` on `defineLocale` ([#2620](https://github.com/nuxt/ui/issues/2620)) ([937585c](https://github.com/nuxt/ui/commit/937585cb3f8bc902d60a4b5904711598204aee2d))
* **locale:** translate chinese ([#2580](https://github.com/nuxt/ui/issues/2580)) ([febda5c](https://github.com/nuxt/ui/commit/febda5c2b67374d1358a66694543b77037d239c6))
* **locale:** translate Spanish ([#2644](https://github.com/nuxt/ui/issues/2644)) ([8ed434c](https://github.com/nuxt/ui/commit/8ed434c105b75ae02aa7493a235cebb64d518d09))
* **locale:** typing `dir` ([#2643](https://github.com/nuxt/ui/issues/2643)) ([e55c0e2](https://github.com/nuxt/ui/commit/e55c0e25947e7bcef931b26dafaad120f488a627))
* **module:** support i18n in components ([#2553](https://github.com/nuxt/ui/issues/2553)) ([2636240](https://github.com/nuxt/ui/commit/26362408b161108487b889ff001bec9166059c79))
* **NavigationMenu:** control items `open` & `defaultOpen` on vertical ([30218f1](https://github.com/nuxt/ui/commit/30218f1b5b0a56207fd4db224ffa0401ac194a04)), closes [#2608](https://github.com/nuxt/ui/issues/2608)
* **PinInput:** implement component ([#2570](https://github.com/nuxt/ui/issues/2570)) ([95aa6f6](https://github.com/nuxt/ui/commit/95aa6f68b316d02c28d1124d9a826bca55cde81f))
* **Popover:** add `prevent-close` prop ([ea97759](https://github.com/nuxt/ui/commit/ea97759c2c219bdf5c48b652b47d293ddf513a00)), closes [#2245](https://github.com/nuxt/ui/issues/2245)
* **SelectMenu:** use `UInput` in search to handle props like icon ([ff1e079](https://github.com/nuxt/ui/commit/ff1e0798d384d40ad82a95fe5faa16acb080efe3)), closes [#2021](https://github.com/nuxt/ui/issues/2021)
* **Table:** add `caption` prop ([446f9c1](https://github.com/nuxt/ui/commit/446f9c1085e96187afdc5c1d7ce3450f8df1a2e1))
### Bug Fixes
* **App:** missing `vue` imports ([ddb4690](https://github.com/nuxt/ui/commit/ddb46905e7e3480ab578bcd8a478f25dff60081a))
* **App:** remove `dir` prop ([#2630](https://github.com/nuxt/ui/issues/2630)) ([7cc26d0](https://github.com/nuxt/ui/commit/7cc26d098dff70923bcd9d414d675018951b1967))
* **Breadcrumb/Carousel/Pagination:** handle icons in RTL mode ([#2633](https://github.com/nuxt/ui/issues/2633)) ([e5119a9](https://github.com/nuxt/ui/commit/e5119a9ca4e217ef769904323c16bd8c0cbc02d9))
* **Breadcrumb:** render as `nav` ([756f791](https://github.com/nuxt/ui/commit/756f791a1a8dd3a4a88c212b4e4f775584decb55)), closes [#2649](https://github.com/nuxt/ui/issues/2649)
* **Button:** improve neutral solid variant hover ([8d85498](https://github.com/nuxt/ui/commit/8d85498ee197ec0b26cdd7c4b08f84fec45ddd8f))
* **Carousel:** use `dir` from locale ([#2647](https://github.com/nuxt/ui/issues/2647)) ([1fbbfe8](https://github.com/nuxt/ui/commit/1fbbfe8df06b3b8b294615ac328d582c5230aa8b))
* **ContextMenu/DropdownMenu:** relative imports with prefix ([47f58f5](https://github.com/nuxt/ui/commit/47f58f52ef2d03176a184a3ca2154f5cea655edb))
* **css:** `--font-family-sans` renamed to `--font-sans` ([#2680](https://github.com/nuxt/ui/issues/2680)) ([b2fa657](https://github.com/nuxt/ui/commit/b2fa65734bb59186520c985f7c73fc34a0cb8b37))
* **css:** remove useless spacing override ([8d00265](https://github.com/nuxt/ui/commit/8d0026558a21efbbca08e9939844f7479a0d6cce))
* **FormField:** missing conditions to apply container classes ([#2631](https://github.com/nuxt/ui/issues/2631)) ([9241ba1](https://github.com/nuxt/ui/commit/9241ba1230b0fde41595634362d83c92c66b7699))
* **Form:** match `error-pattern` on input validation ([#2606](https://github.com/nuxt/ui/issues/2606)) ([3584a33](https://github.com/nuxt/ui/commit/3584a3328b8588f024557c9908242bc374853419))
* **InputMenu/SelectMenu:** init `filter` with `labelKey` ([18931ac](https://github.com/nuxt/ui/commit/18931acdb316bc72a3e5ed6d20985688ad5c8d99))
* **InputMenu/SelectMenu:** look in `items` only with `value-attribute` ([0ceafe1](https://github.com/nuxt/ui/commit/0ceafe1d54000f3eb49562b00c188d82fa23c4ee)), closes [#2464](https://github.com/nuxt/ui/issues/2464)
* **InputMenu/SelectMenu:** multiple not working with generic boolean casting ([503f701](https://github.com/nuxt/ui/commit/503f701c7ecdfe27e9057e5ddebfc7e03889d61b)), closes [#2541](https://github.com/nuxt/ui/issues/2541)
* **InputMenu/SelectMenu:** use `isEqual` from `ohash` ([f943f88](https://github.com/nuxt/ui/commit/f943f88fcc9f4678d8f7bd224799e289a0c57dd8))
* **Link:** missing relative import ([#2588](https://github.com/nuxt/ui/issues/2588)) ([95a0bbc](https://github.com/nuxt/ui/commit/95a0bbc581a40677f620eed3170f9a423976214b))
* **locale:** Improve German translation ([#2676](https://github.com/nuxt/ui/issues/2676)) ([992be91](https://github.com/nuxt/ui/commit/992be91823fe1877254ccd092c71c77dd3ff42f7))
* **locale:** it translation ([#2623](https://github.com/nuxt/ui/issues/2623)) ([73e25ed](https://github.com/nuxt/ui/commit/73e25ed23562f755ea4c66e6c5fb06dd18caac1e))
* **locale:** Italian translation ([#2584](https://github.com/nuxt/ui/issues/2584)) ([d167c9b](https://github.com/nuxt/ui/commit/d167c9b807a82fdf0fd280ce8417a66f86d7ed72))
* **Modal/Slideover:** prevent `esc` with `prevent-close` prop ([9e2cc5b](https://github.com/nuxt/ui/commit/9e2cc5b12567472044726924a3896b4b0e7993a1)), closes [#2501](https://github.com/nuxt/ui/issues/2501)
* **module:** remove `fast-deep-equal` in favor of custom `isEqual` ([37a3597](https://github.com/nuxt/ui/commit/37a359701f4b2ce4a9b0727b64c0e3eea6be00b4))
* **module:** skip devtools renderer page injection if router integration is disabled ([#2571](https://github.com/nuxt/ui/issues/2571)) ([afe4003](https://github.com/nuxt/ui/commit/afe40033b088d8aedb73fa8387a0284ef78444e4))
* **PinInput:** missing `useFormField` import ([601f4b2](https://github.com/nuxt/ui/commit/601f4b2cd2027817b935e02a0b4584dc3dce655f))
* **Textarea:** `autoresize` does not work when initializing `modelValue` ([#2681](https://github.com/nuxt/ui/issues/2681)) ([d3a079a](https://github.com/nuxt/ui/commit/d3a079a644db3dfe2f4e9567973550d74b3ba905))
* **Toaster:** teleport to `body` ([b0be26d](https://github.com/nuxt/ui/commit/b0be26d67feab467ac5862edd82e52df03a5091c)), closes [#2404](https://github.com/nuxt/ui/issues/2404)
* **Toast:** unreachable behind overlays ([#2650](https://github.com/nuxt/ui/issues/2650)) ([0daac5b](https://github.com/nuxt/ui/commit/0daac5bafb756c3a2dfaf2bf166c30c0eb476e08))
* **useLocale:** missing import in various components ([#2603](https://github.com/nuxt/ui/issues/2603)) ([df7a61a](https://github.com/nuxt/ui/commit/df7a61a97a14b3d7943baee6a74686134dfdb10b))
### Reverts
* Revert "docs(ComponentCode/ComponentExample): use relative imports" ([5deadc7](https://github.com/nuxt/ui/commit/5deadc709640bbfd3ec14c1c9363deb55e765d6a))
## [3.0.0-alpha.8](https://github.com/nuxt/ui/compare/v3.0.0-alpha.7...v3.0.0-alpha.8) (2024-11-07)
### ⚠ BREAKING CHANGES
* **theme:** migrate from `heroicons` to `lucide` (#2540)
### Features
* **Avatar:** infer `width` / `height` on `<img>` based on `size` prop ([c9adf33](https://github.com/nuxt/ui/commit/c9adf333be3e489b91fd044189809c28c62e7951))
* **Avatar:** use `NuxtImg` component when available ([f1a14dd](https://github.com/nuxt/ui/commit/f1a14dd87c3e250a7eaa6729f68201201a476f9f)), closes [nuxt/ui#2078](https://github.com/nuxt/ui/issues/2078)
* **Badge:** handle `icon` and `avatar` props ([#2497](https://github.com/nuxt/ui/issues/2497)) ([2d52834](https://github.com/nuxt/ui/commit/2d52834529e00a43b1a9b3015d073500b4208981))
* **components:** improve RTL support ([#2433](https://github.com/nuxt/ui/issues/2433)) ([94c4918](https://github.com/nuxt/ui/commit/94c49186e16d84d77a637bbdfe00e7cb880204fe))
* **DropdownMenu/ContextMenu:** handle `color` field in items ([#2510](https://github.com/nuxt/ui/issues/2510)) ([f66c96e](https://github.com/nuxt/ui/commit/f66c96e277970f80c905a8936c73b1d37479a940))
* **InputMenu/Select/SelectMenu:** `arrow` prop implementation ([#2503](https://github.com/nuxt/ui/issues/2503)) ([f26f6c8](https://github.com/nuxt/ui/commit/f26f6c8168ad5e44e47ab770cee10035257841a2))
* **Kbd:** special keys for macOS and other systems ([#2494](https://github.com/nuxt/ui/issues/2494)) ([332c6c0](https://github.com/nuxt/ui/commit/332c6c08d73ebdbffc18e1f196962eaa76e7a8dc))
* **module:** add support for `vue` using `unplugin` ([#2416](https://github.com/nuxt/ui/issues/2416)) ([d4a943e](https://github.com/nuxt/ui/commit/d4a943e631b5e16dc7863395f1dd906087228e1c))
* **module:** devtools integration ([#2196](https://github.com/nuxt/ui/issues/2196)) ([701c75a](https://github.com/nuxt/ui/commit/701c75a2a88a29be2fce193f75e1484799a5539c))
* **NavigationMenu:** add `item-content` slot ([b5ca0d9](https://github.com/nuxt/ui/commit/b5ca0d96f1de049dde698e57a340fc8ee54dd2e7))
* **Table:** customize `header` and `cell` through slots ([#2457](https://github.com/nuxt/ui/issues/2457)) ([ef561e7](https://github.com/nuxt/ui/commit/ef561e7cba172b61f296d4ff11815ec31902fb4a))
* **theme:** migrate from `heroicons` to `lucide` ([#2540](https://github.com/nuxt/ui/issues/2540)) ([a6c1a6c](https://github.com/nuxt/ui/commit/a6c1a6c587ca35439852ce93cd4edc5041c6a9bf))
### Bug Fixes
* **ButtonGroup:** merge class with theme ([d980115](https://github.com/nuxt/ui/commit/d9801154088ec7a20901b805f5d21e485e481d98)), closes [nuxt/ui#2498](https://github.com/nuxt/ui/issues/2498)
* **Carousel:** add missing `aria-label` on dots ([#2489](https://github.com/nuxt/ui/issues/2489)) ([03dd1eb](https://github.com/nuxt/ui/commit/03dd1eba7ece4c48393960dc6c725be3a1eec776))
* **Chip:** proxy attrs to slot ([8669553](https://github.com/nuxt/ui/commit/8669553ea415cc969b2066a78830d03e8dfc811b)), closes [nuxt/ui#2484](https://github.com/nuxt/ui/issues/2484)
* **components:** missing relative imports ([1a93d13](https://github.com/nuxt/ui/commit/1a93d13a1609d8b90783f20b330738cd7456503e)), closes [nuxt/ui#2515](https://github.com/nuxt/ui/issues/2515)
* **InputMenu/Select/SelectMenu:** improve types ([#2471](https://github.com/nuxt/ui/issues/2471)) ([db8111d](https://github.com/nuxt/ui/commit/db8111d7835d030ced79899e826ff1eb74cf1cf4))
* **InputMenu/SelectMenu:** `fast-deep-equal` import ([309e52f](https://github.com/nuxt/ui/commit/309e52faa76fc0a135dbc0d9543380ffd9066bda)), closes [nuxt/ui#2488](https://github.com/nuxt/ui/issues/2488)
* **module:** add `fast-deep-equal` in `optimizeDeps` ([0bfe2b6](https://github.com/nuxt/ui/commit/0bfe2b60b3eb06ec30c80505f10380bab4f7ad4c))
* **module:** define `[#build](https://github.com/nuxt/ui/issues/build)/app.config` ([12ae20d](https://github.com/nuxt/ui/commit/12ae20df20db18d233a185c59ede7dcaeca93071)), closes [nuxt/ui#2532](https://github.com/nuxt/ui/issues/2532)
* **NavigationMenu:** add missing `min-w-0` to make truncate work ([#2476](https://github.com/nuxt/ui/issues/2476)) ([1402436](https://github.com/nuxt/ui/commit/1402436c2b0262edada04273b60c3b2914df2895))
* **NavigationMenu:** enforce `data-orientation` ([64ad4b6](https://github.com/nuxt/ui/commit/64ad4b6892d827df921550bf7ae31048d8d6cc50))
* **NavigationMenu:** improve generic types ([#2482](https://github.com/nuxt/ui/issues/2482)) ([fc2015b](https://github.com/nuxt/ui/commit/fc2015bb0e9ccb017a91ba1ee839cd84cf740cf3))
* **Table:** types in undeclared slots ([#2544](https://github.com/nuxt/ui/issues/2544)) ([f821e66](https://github.com/nuxt/ui/commit/f821e6681bfc5d1515fe7158fe3fda639a897ac8))
* **Tabs:** same behaviour between `pill` and `link` variants ([e592da2](https://github.com/nuxt/ui/commit/e592da2fcb9deb5ad5f2ffb442ff07d86923bab6)), closes [#2338](https://github.com/nuxt/ui/issues/2338)
* **templates:** type error in app config ([77d18d8](https://github.com/nuxt/ui/commit/77d18d8ab7bf28aee316a443d52b852dfc5fd1ca)), closes [nuxt/ui#2481](https://github.com/nuxt/ui/issues/2481)
* **useKbd:** hydration issue ([845f85a](https://github.com/nuxt/ui/commit/845f85a072598f47c7afe10c4e5ebcc480450113)), closes [#2494](https://github.com/nuxt/ui/issues/2494)
* **utils:** improve `escapeRegExp` function ([a97c511](https://github.com/nuxt/ui/commit/a97c511279d32747b487ab5de32677e36a884e53))
## [3.0.0-alpha.7](https://github.com/nuxt/ui/compare/v3.0.0-alpha.6...v3.0.0-alpha.7) (2024-10-23)
### ⚠ BREAKING CHANGES
* **components:** rename `select` to `onSelect` on items
### Features
* **Accordion/Breadcrumb/CommandPalette/ContextMenu/DropdownMenu/NavigationMenu/Tabs:** add `labelKey` prop ([acfc6ce](https://github.com/nuxt/ui/commit/acfc6cef2db88774749d38a98416fdd85922d513))
* **Button:** handle `avatar` prop ([a54c3e4](https://github.com/nuxt/ui/commit/a54c3e49fe782e329f9245e496c336143e3e4b23))
* **CommandPalette:** handle `loading` field in items ([49abad2](https://github.com/nuxt/ui/commit/49abad243cee97b99753e2500c4bdaa0efe5eb75))
* **ContextMenu/DropdownMenu:** handle `checkbox` items type ([8ef6e71](https://github.com/nuxt/ui/commit/8ef6e712acbb2fc026eb35cefa8e29fc0b59d70f)), closes [#2144](https://github.com/nuxt/ui/issues/2144)
* **ContextMenu/DropdownMenu:** handle `loading` field in items ([b975235](https://github.com/nuxt/ui/commit/b975235c8b8e693a32efd3fd5381eed88fa3db4d))
* **Form:** add `superstruct` validation ([#2363](https://github.com/nuxt/ui/issues/2363)) ([5385944](https://github.com/nuxt/ui/commit/53859443593b584f7cd44106021e80f441e9ca06))
* **Input/InputMenu/Select/SelectMenu:** handle `avatar` prop ([53a3796](https://github.com/nuxt/ui/commit/53a3796d1b08717a589028f99fc01084df661708))
* **InputMenu/RadioGroup/Select/SelectMenu:** handle `labelKey` and use `get` to support dot notation ([f6f9823](https://github.com/nuxt/ui/commit/f6f9823b15d84362d093703cb15ecba64c73c2c2))
* **NavigationMenu:** handle children on `vertical` orientation ([#2384](https://github.com/nuxt/ui/issues/2384)) ([34bddd4](https://github.com/nuxt/ui/commit/34bddd45be2ba1d51ddb9b6b40860f2414f63180))
* **Table:** implement component ([#2364](https://github.com/nuxt/ui/issues/2364)) ([b54950e](https://github.com/nuxt/ui/commit/b54950e3ed77a466eb048788757a76018638eafa))
### Bug Fixes
* **AvatarGroup:** wrong ring on big sizes ([61b2323](https://github.com/nuxt/ui/commit/61b232377b4b1fb41de30fd33e690a36b36ba575))
* **Button:** invalid hover on `link` variant ([df2013c](https://github.com/nuxt/ui/commit/df2013ca92a49b5947e2fbc2641fd92860c32042))
* **Checkbox:** `indeterminate` prop not working ([f6631ff](https://github.com/nuxt/ui/commit/f6631ff7bc607e140e9db2c7335c409a811820e4))
* **components:** rename `select` to `onSelect` on items ([b39c4d1](https://github.com/nuxt/ui/commit/b39c4d127e0ddf7607e868ecc83930ca49436bad))
* **css:** `font-sans` already applied on <html> ([9e03da4](https://github.com/nuxt/ui/commit/9e03da41b3537236864ae2a533c47e99a6270b77))
* **css:** make `[@theme](https://github.com/theme)` default ([a2bad2e](https://github.com/nuxt/ui/commit/a2bad2eee2d2a9255152692898078d26e9ecad98))
* **Drawer/Modal/Slideover:** no need for `z-index` since its isolated ([bcfa4b7](https://github.com/nuxt/ui/commit/bcfa4b74a9713be764ecb6db93d60d1360e52f07)), closes [nuxt/ui#2347](https://github.com/nuxt/ui/issues/2347)
* **Input/InputMenu/Select/SelectMenu:** uniformize placeholder color ([f59844b](https://github.com/nuxt/ui/commit/f59844bb617f50ef78ae5abe250b0744d7341a2f))
* **InputMenu/SelectMenu:** escape regexp before search ([7c21dde](https://github.com/nuxt/ui/commit/7c21ddefa87bf3d9999c0e790b48c004c078304d))
* **InputMenu/SelectMenu:** improve displayed value ([0f9ac87](https://github.com/nuxt/ui/commit/0f9ac8733e402d1f22a3eb6c1e24a8d5607b3572)), closes [nuxt/ui#2353](https://github.com/nuxt/ui/issues/2353)
* **InputMenu:** emit `focus` event ([#2386](https://github.com/nuxt/ui/issues/2386)) ([7802aac](https://github.com/nuxt/ui/commit/7802aacf3f5be572dd64c3288196432a41f06b0e))
* **module:** stop using tailwind's shorthand arbitrary variable syntax ([#2366](https://github.com/nuxt/ui/issues/2366)) ([dcce571](https://github.com/nuxt/ui/commit/dcce571cdab08de8408c8ba6b236b051eec3a603))
* **Slideover:** set max height on `top` / `bottom` positions ([a68016e](https://github.com/nuxt/ui/commit/a68016ec5d6859e892c90333d35fd7db09fdcf10)), closes [nuxt/ui#2388](https://github.com/nuxt/ui/issues/2388)
## [3.0.0-alpha.6](https://github.com/nuxt/ui/compare/v3.0.0-alpha.5...v3.0.0-alpha.6) (2024-10-09)
### ⚠ BREAKING CHANGES
* **module:** implement design system with CSS variables (#2298)
### Features
* **Carousel:** implement component ([#2288](https://github.com/nuxt/ui/issues/2288)) ([68ee3f1](https://github.com/nuxt/ui/commit/68ee3f11ca01b19cf890ef8105ffb87ef9bb3188))
* **Form:** add Standard Schema support ([#2303](https://github.com/nuxt/ui/issues/2303)) ([0955c07](https://github.com/nuxt/ui/commit/0955c07edd8ea5b5c39b770804b8e4c6f86d94b0))
* **module:** implement `--ui-radius` CSS variable ([#2341](https://github.com/nuxt/ui/issues/2341)) ([057e86c](https://github.com/nuxt/ui/commit/057e86cfda1ef5c7a370c99ef409d22e48772ca7))
* **module:** set `disableTransition` option on `@nuxtjs/color-mode` ([b82af02](https://github.com/nuxt/ui/commit/b82af02839b7d75344d9431fabdc42f0ac0681e1))
### Bug Fixes
* **Accordion:** use `text-left break-words` instead of `truncate` on label ([6c7c2f0](https://github.com/nuxt/ui/commit/6c7c2f02f395747a0c68a499630f502e3f02ded3))
* **Alert:** default variant to `solid` for consistency ([3a7c5c2](https://github.com/nuxt/ui/commit/3a7c5c26011bfcffcdf6ac3451adb2af1453b9db))
* **Button:** center text with `block` prop ([3cf5535](https://github.com/nuxt/ui/commit/3cf5535b2faa28b557ca55d694abdfa7d7ad0efc)), closes [nuxt/ui#2317](https://github.com/nuxt/ui/issues/2317)
* **Carousel:** move embla plugins to `dependencies` ([bee04ad](https://github.com/nuxt/ui/commit/bee04adf4cc4fd6d69e93ad94500f5ef604405e7))
### Code Refactoring
* **module:** implement design system with CSS variables ([#2298](https://github.com/nuxt/ui/issues/2298)) ([9368c6a](https://github.com/nuxt/ui/commit/9368c6a63955a2e6c2f4f900a9b91c61bb2e5a72))
## [3.0.0-alpha.5](https://github.com/nuxt/ui/compare/v3.0.0-alpha.4...v3.0.0-alpha.5) (2024-10-02)
### Features
* **module:** enable `@nuxtjs/color-mode` ([9dcf903](https://github.com/nuxt/ui/commit/9dcf903926046b6e92b4784043e374d2174e4201))
* **module:** override `dark` variant with class strategy ([0f86b87](https://github.com/nuxt/ui/commit/0f86b87385375e5bd859e84d21f8b4f06b0a99e0))
### Bug Fixes
* **Button:** props specified more than once ([66a04ad](https://github.com/nuxt/ui/commit/66a04add91389910e1336bf0be1cfeada3540f76))
## [3.0.0-alpha.4](https://github.com/nuxt/ui/compare/v3.0.0-alpha.3...v3.0.0-alpha.4) (2024-10-01)
### Features
* **Drawer:** handle `direction` + `handle` props ([5f77aac](https://github.com/nuxt/ui/commit/5f77aac368448c7c45a0f9238d2dc3a5b0de825e))
### Bug Fixes
* **Accordion:** missing `min-w-0` on trigger ([6c28597](https://github.com/nuxt/ui/commit/6c285977bd175d4866ca601bca47132ebb2d3440))
* **build.config:** disable mkdist `addRelativeDeclarationExtensions` option ([f54f607](https://github.com/nuxt/ui/commit/f54f6074131db0f68eab1edcde3a4b2a7ecaba92))
* **CommandPalette:** missing `min-w-0` on root ([a61e765](https://github.com/nuxt/ui/commit/a61e7656c25b26409cab77178e67d1cb9ec22dbd))
* **Drawer:** improve max-width on mobile ([fac52fa](https://github.com/nuxt/ui/commit/fac52fa933aeb02f0855d20be37c4214efba0ab7))
* **InputMenu:** missing `group` on trailing ([2c7c41b](https://github.com/nuxt/ui/commit/2c7c41bd046a961d398bbe8ee4a5945cd1fbaeab))
* **README:** npm badge link ([#2271](https://github.com/nuxt/ui/issues/2271)) ([30c33c7](https://github.com/nuxt/ui/commit/30c33c71134ccbea4258949a851eaf8b26213b60))
* **templates:** app config colors type ([96c9246](https://github.com/nuxt/ui/commit/96c9246d83b54637ceb2e2dd77542e435690c387))
* **Toast:** improve focus styles ([1f9abda](https://github.com/nuxt/ui/commit/1f9abdae614acbfa0be868a599071a601406f0f5))
### Reverts
* Revert "chore(deps): refresh lock" ([b83ecc9](https://github.com/nuxt/ui/commit/b83ecc9a6f309d37d3f096667143a4ed7700db6d))
## [3.0.0-alpha.3](https://github.com/nuxt/ui/compare/v3.0.0-alpha.2...v3.0.0-alpha.3) (2024-09-18)
### Features
* **module:** move `colors` options into `theme.colors` ([2e95446](https://github.com/nuxt/ui/commit/2e954467c4679d70b68d3155ae34eca300508e38))
## [3.0.0-alpha.2](https://github.com/nuxt/ui/compare/v3.0.0-alpha.1...v3.0.0-alpha.2) (2024-09-18)
### Features
* **Button:** loading-auto ([#2198](https://github.com/nuxt/ui/issues/2198)) ([ed18e74](https://github.com/nuxt/ui/commit/ed18e7454986ed104fc73b77e88573b3c1df8566))
* **module:** improve options ([5076b8c](https://github.com/nuxt/ui/commit/5076b8cc9e908cf289150c668b1707dc1397dba3))
* **module:** install `@nuxt/fonts` by default ([8898a5d](https://github.com/nuxt/ui/commit/8898a5d6758b1047e35bcdf648362c42de387488))
### Bug Fixes
* **Button:** button link not showing disabled classes ([#2189](https://github.com/nuxt/ui/issues/2189)) ([7c2adf2](https://github.com/nuxt/ui/commit/7c2adf2f7fc88174897cc775c752414a8b84f3a9))
* **Button:** duplicate click handlers ([#2213](https://github.com/nuxt/ui/issues/2213)) ([dd6bf56](https://github.com/nuxt/ui/commit/dd6bf5694ff05ed1eeb9df8c42f833f51dbec66e))
* **playground:** typecheck ([cf92c5f](https://github.com/nuxt/ui/commit/cf92c5f3f0e0f329844ee60772773a844ea1cc71))
## [3.0.0-alpha.1](https://github.com/nuxt/ui/compare/v3.0.0-alpha.0...v3.0.0-alpha.1) (2024-09-11)
### Features
* **module:** hard-code css file to be imported anywhere ([62a2643](https://github.com/nuxt/ui/commit/62a2643a80e7ab6c6e154ba59801d393d9a53c40))
### Bug Fixes
* **ContextMenu/DropdownMenu:** lint unused var ([a03a55c](https://github.com/nuxt/ui/commit/a03a55cf8d89c45fba6607f83b67367cfd419c3e))
* import from `../types/index` ([3e28c8f](https://github.com/nuxt/ui/commit/3e28c8f35a64a7c19ce18f36dbe580503f2050bc))
* **Link:** only bind necessary slot props ([7fe7ff6](https://github.com/nuxt/ui/commit/7fe7ff6fe2055d29b7fd54793ca52850842294e3))
* **NavigationMenu:** handle open state hover effect ([84186e5](https://github.com/nuxt/ui/commit/84186e52e997a4dd55f98bf7bc0199656943b9c9))
* **plugins:** infer type from `[#app](https://github.com/nuxt/ui/issues/app)` to remove build warning ([debf9cc](https://github.com/nuxt/ui/commit/debf9cc85339b7b162ac34392757214a16dad977))
* **README:** license link ([71428da](https://github.com/nuxt/ui/commit/71428da3dc9c6f17a6e21b2bd889f6090be127d6))
* **templates:** augment `@nuxt/schema` rather than `nuxt/schema` ([40b3570](https://github.com/nuxt/ui/commit/40b3570343dc68684d3ecf03e1a439e815f57ba3))
* **types:** no longer need to import types with `/index` suffix ([8277167](https://github.com/nuxt/ui/commit/82771673f20b6ece7e126a4f8914311473d687e3))
* **useButtonGroup:** lint ([97d0593](https://github.com/nuxt/ui/commit/97d05936cd198026e6c4d66920266e0b4b85242c))
## [3.0.0-alpha.0](https://github.com/nuxt/ui/compare/v2.15.0...v3.0.0-alpha.0) (2024-09-05)
### ⚠ BREAKING CHANGES
* **module:** move `primary` and `gray` inside `colors` object
* **Link:** expose `active` instead of `isActive` in default slot
### Features
* **Accordion:** add `body` slot to solve animation flick ([85d1723](https://github.com/nuxt/ui/commit/85d172339f690aeb83a7ae7d3ad812938bb6e000))
* **Accordion:** add `trailingIcon` prop ([fc3d42d](https://github.com/nuxt/ui/commit/fc3d42d5eaba9491ae21f05025899219346f5ca4))
* **Accordion:** new component ([a21648a](https://github.com/nuxt/ui/commit/a21648a1918584b3f4036da96604be66e560b71c))
* add `transition-colors` on hover effects ([633a394](https://github.com/nuxt/ui/commit/633a39452aa28afe4a523f458787fc5102d28ee6))
* **Alert/CommandPalette/Modal/Slideover/Toast:** handle `closeIcon` and uniformize `close` prop ([e4eef89](https://github.com/nuxt/ui/commit/e4eef8976742ac5de418af0fe80d79bfd32fa83f))
* **Alert:** add `actions` slot ([2d15709](https://github.com/nuxt/ui/commit/2d157090c029afb715706e7b464d37c0c377ea82))
* **Alert:** new component ([1535313](https://github.com/nuxt/ui/commit/1535313596cd144886b887ede295da980f394082)), closes [#23](https://github.com/nuxt/ui/issues/23)
* **Avatar:** bind `as` to image to support `NuxtImg` ([cff37bf](https://github.com/nuxt/ui/commit/cff37bf211ddcf67a67ef66dc526ba6cd780ff21))
* **AvatarGroup:** new component ([#71](https://github.com/nuxt/ui/issues/71)) ([def5f7c](https://github.com/nuxt/ui/commit/def5f7c10bd28fbfea5fb8a3c7314ff8592c5335))
* **Avatar:** new component ([978595c](https://github.com/nuxt/ui/commit/978595ce88bfef959f3cd6f405b405727e3929e0))
* **Breacrumb/ContextMenu/DropdownMenu/NavigationMenu:** bind item `class` on link ([d13e27e](https://github.com/nuxt/ui/commit/d13e27eb5bd75227f6e67cbcdfdfe31dcf59e2e4))
* **Breadcrumb:** new component ([53a2bc0](https://github.com/nuxt/ui/commit/53a2bc02642ec9ccecc71fa60cdd2913a4de5214)), closes [#22](https://github.com/nuxt/ui/issues/22)
* **Breadcrumb:** rename `links` to `items` + improve slots ([d56d3a1](https://github.com/nuxt/ui/commit/d56d3a13e3240fedeadcbd8bcadb5c732b7ce2bc))
* **Button:** add `subtle` variant ([1d2e1ca](https://github.com/nuxt/ui/commit/1d2e1caaf5edcbad55bc5c3c75da8afc90ab7a94))
* **ButtonGroup:** new component ([#88](https://github.com/nuxt/ui/issues/88)) ([43066fd](https://github.com/nuxt/ui/commit/43066fd9ea971c6b6c3bf5d58383bb2c9cd076a3))
* **Button:** use `useComponentIcons` ([6e10a09](https://github.com/nuxt/ui/commit/6e10a0942fb408c7092a95f9251ff763a8c3b2d0))
* **Card:** new component ([78908c3](https://github.com/nuxt/ui/commit/78908c3d64a6759a915b5a8b772e750f928740e4))
* **Checkbox/Progress/RadioGroup/Slider/Switch:** add `black` color ([08c91fe](https://github.com/nuxt/ui/commit/08c91fe8f1b7b8d0571bd140e05363e4b71ab6d8))
* **Checkbox:** new component ([#67](https://github.com/nuxt/ui/issues/67)) ([bfd5988](https://github.com/nuxt/ui/commit/bfd59883584aee4c1a0a88952f4277c52afdf2ca))
* **Chip:** new component ([d6bebd5](https://github.com/nuxt/ui/commit/d6bebd5ef9fb40e946a6e6a34c44aff8639c4290))
* **cli:** `init` command ([cdd9b17](https://github.com/nuxt/ui/commit/cdd9b178f32b9807c451734b85c4cfb9f5e8438d))
* **CommandPalette:** handle `filter` false and `postFilter` ([1ef977f](https://github.com/nuxt/ui/commit/1ef977fb8c3a754a909a82733f31b1b45577f021))
* **CommandPalette:** implement group `filter` function ([e29cf79](https://github.com/nuxt/ui/commit/e29cf793cbc46a960dd66241f3bb716887038d18))
* **CommandPalette:** improve theme and performance ([20476f4](https://github.com/nuxt/ui/commit/20476f4b9a95817598fb2e2ae5cb383b0d1411e2))
* **CommandPalette:** new component ([#80](https://github.com/nuxt/ui/issues/80)) ([d0017bf](https://github.com/nuxt/ui/commit/d0017bf847c05f64c3bd131b9e57b2f90009fbe3))
* **components:** allow override of sizes through `ui` prop ([6aa0ea3](https://github.com/nuxt/ui/commit/6aa0ea306f2b89a900c86b1a411217d108d399c0))
* **components:** uniformize colors and variants ([#141](https://github.com/nuxt/ui/issues/141)) ([c018c23](https://github.com/nuxt/ui/commit/c018c23224167df3594f39157d3cb35f0118534b))
* **ContextMenu:** handle `size` prop ([#130](https://github.com/nuxt/ui/issues/130)) ([aa832f3](https://github.com/nuxt/ui/commit/aa832f32a0ddfc6068537f6322603c0fa6f8b1df))
* **ContextMenu:** new component ([65a3b0a](https://github.com/nuxt/ui/commit/65a3b0a2d0f8a4e32b9c0ce4707f22268b32e3dc)), closes [#18](https://github.com/nuxt/ui/issues/18)
* **defineShortcuts:** migrate with reactivity ([#72](https://github.com/nuxt/ui/issues/72)) ([80b413a](https://github.com/nuxt/ui/commit/80b413a724d0702d66df9488b9a974f0d7ba0d41))
* **Drawer:** implement with `vaul-vue` ([5e6275f](https://github.com/nuxt/ui/commit/5e6275fcff151f3607939b1503ff60f970375564)), closes [#53](https://github.com/nuxt/ui/issues/53)
* **DropdownMenu:** add `[#item](https://github.com/nuxt/ui/issues/item)` slot for consistency ([1dcc1f5](https://github.com/nuxt/ui/commit/1dcc1f50740c1b4ed17c77a22562ccd662c85d15))
* **DropdownMenu:** handle `size` prop ([#125](https://github.com/nuxt/ui/issues/125)) ([dfa9936](https://github.com/nuxt/ui/commit/dfa99362d4d70ac76c43a1b1c3e815272bee9a25))
* **DropdownMenu:** handle item type `separator` ([a5bb25d](https://github.com/nuxt/ui/commit/a5bb25dd95be81d34564c5b5c4e3174ec126dbdb))
* **DropdownMenu:** new component ([#37](https://github.com/nuxt/ui/issues/37)) ([4403350](https://github.com/nuxt/ui/commit/44033508a7347a5c75204d359b641a6f2da2cff9))
* **DropdownMenu:** pass `index` to slots ([735f81e](https://github.com/nuxt/ui/commit/735f81e771d3673f444be99b93cff1ef93c3ac6c))
* expose `open` state to slots ([ed2c45a](https://github.com/nuxt/ui/commit/ed2c45ac76285bb394fa16970fca27690d3de454))
* **Form:** `Select` and `InputMenu` integration ([#97](https://github.com/nuxt/ui/issues/97)) ([52cf471](https://github.com/nuxt/ui/commit/52cf471099a78737e13f755fd89ff38c8c761aea))
* **Form:** nested form validation ([#23](https://github.com/nuxt/ui/issues/23)) ([1671278](https://github.com/nuxt/ui/commit/167127861f117ece8a54421b5000f50d8d611b39))
* **Form:** new component ([#4](https://github.com/nuxt/ui/issues/4)) ([de62676](https://github.com/nuxt/ui/commit/de62676647531c4d0a40c4696f9a7a3b75af32ff))
* **Form:** support for `valibot@33` ([#132](https://github.com/nuxt/ui/issues/132)) ([20acc92](https://github.com/nuxt/ui/commit/20acc92eecbd17b9a6ea16ed688fe39af94708a2))
* **Icon:** use `@antfu/nuxt-icon-poc` ([#76](https://github.com/nuxt/ui/issues/76)) ([142affb](https://github.com/nuxt/ui/commit/142affb9a72faa07bb9b448a95042c13aec09623))
* **Input/Textarea:** expose ref ([74a6bca](https://github.com/nuxt/ui/commit/74a6bca2b334f54b99294be8848f345e69ff1141))
* **Input:** handle icons ([de8100a](https://github.com/nuxt/ui/commit/de8100af3a36253d32d449a9bd445a761386b724))
* **InputMenu/Select/SelectMenu:** introduce `valueKey` prop ([eeec967](https://github.com/nuxt/ui/commit/eeec9676cde0201736d70739847ee820fb80657c)), closes [#108](https://github.com/nuxt/ui/issues/108)
* **InputMenu:** expose `modelValue` and `open` to slots ([659d5e2](https://github.com/nuxt/ui/commit/659d5e2c5a9164c684cb49429d5045bdae11eac6))
* **InputMenu:** handle `multiple` ([fe3ab65](https://github.com/nuxt/ui/commit/fe3ab652b4b9258cd02c48ded5b8858001818e03)), closes [#91](https://github.com/nuxt/ui/issues/91)
* **InputMenu:** handle `size` prop ([#131](https://github.com/nuxt/ui/issues/131)) ([18c5ead](https://github.com/nuxt/ui/commit/18c5ead1bd1f253524da587305c234a88c56ed25))
* **InputMenu:** new component ([#86](https://github.com/nuxt/ui/issues/86)) ([99f20a4](https://github.com/nuxt/ui/commit/99f20a4154b26f75fbec0762d5a02a08b5a319a7))
* **Input:** set `autocomplete` to `off` by default ([eba8b4b](https://github.com/nuxt/ui/commit/eba8b4b31a3d83d4dcb67246eed0fc21fb46dce7))
* **Input:** use `defineModel` ([#61](https://github.com/nuxt/ui/issues/61)) ([091f8e9](https://github.com/nuxt/ui/commit/091f8e91c45039391800de80807ce77db3656500))
* **Kbd:** add `color` prop ([2cc41de](https://github.com/nuxt/ui/commit/2cc41dedcfe73183a285a5ce5e7192290926771b))
* **Link:** break component in two with `custom` prop ([3ed5a08](https://github.com/nuxt/ui/commit/3ed5a085181be75d25178640d686274745e54aa3))
* **Link:** style with app config ([349780d](https://github.com/nuxt/ui/commit/349780dae18e3acc4cd1dda8152ae6d0377004ba))
* **Modal:** new component ([5d1d5b3](https://github.com/nuxt/ui/commit/5d1d5b33e8fe959644e5f93986c9c7630ea288cc))
* **Modal:** open programmatically ([#78](https://github.com/nuxt/ui/issues/78)) ([2bf99e1](https://github.com/nuxt/ui/commit/2bf99e1eb4df7333a46df666c446ba7af4e54e93))
* **module:** add `[@source](https://github.com/source)` when `@nuxt/content` is present ([8dfac7f](https://github.com/nuxt/ui/commit/8dfac7fd574bef3ea714e21b852c50aafd6feff4))
* **module:** add option to disable transitions ([5f4fd97](https://github.com/nuxt/ui/commit/5f4fd972ff2251863751549271a9e80123fdbfc8))
* **module:** allow `tailwind.css` customization ([8d560bd](https://github.com/nuxt/ui/commit/8d560bdd212bbbf25a7d4a706a99cc57721d593e))
* **module:** move `primary` and `gray` inside `colors` object ([ccbaf6e](https://github.com/nuxt/ui/commit/ccbaf6ea150e0902d7150585bd09f132fc26ff89))
* **NavigationMenu:** handle content, `color`, `variant`, etc. ([1af449d](https://github.com/nuxt/ui/commit/1af449d6e0e2cd454425d8bc6bf1482e5dac99fd))
* **NavigationMenu:** improve theme with `line` variant and border ([ec6ebba](https://github.com/nuxt/ui/commit/ec6ebbacbe1a0797ec86fe85197a98b084e27e5d))
* **NavigationMenu:** new component ([0d4d86d](https://github.com/nuxt/ui/commit/0d4d86d79db488b79ca2baf7d620b415a36cb135))
* **NavigationMenu:** pass `index` to slots ([0f10d98](https://github.com/nuxt/ui/commit/0f10d9882099256a77b86e5786a7e2ee71c83d46))
* **NavigationMenu:** rename `links` to `items` + improve slots ([ea19a30](https://github.com/nuxt/ui/commit/ea19a3061fb49960fe3b9d28d05cec8fd7f6647e))
* **NavigationMenu:** replace `line` variant with `highlight` prop ([af43b5d](https://github.com/nuxt/ui/commit/af43b5df250fb65bf9696b5b3fb6cb507b2184a1))
* **Pagination:** allow using pagination buttons as links ([#114](https://github.com/nuxt/ui/issues/114)) ([5c5676e](https://github.com/nuxt/ui/commit/5c5676edf957230bf3ac53fa527b1b4b4373750f))
* **Pagination:** new component ([c36bae4](https://github.com/nuxt/ui/commit/c36bae4b21e4a6c899be39800ca90051f79db1e0)), closes [#11](https://github.com/nuxt/ui/issues/11)
* **Popover:** handle `hover` mode ([7b89601](https://github.com/nuxt/ui/commit/7b8960124fcf24a5d3869e3913ea5220af3a76bf))
* **Popover:** new ([c131ce9](https://github.com/nuxt/ui/commit/c131ce955f23ce2613f5493689df8352de3cd4b6))
* **Progress:** new component ([#75](https://github.com/nuxt/ui/issues/75)) ([138cb2d](https://github.com/nuxt/ui/commit/138cb2d12d9414813beed22dcedcee61e3d4f6de))
* **RadioGroup:** handle `horizontal` orientation ([#74](https://github.com/nuxt/ui/issues/74)) ([8144372](https://github.com/nuxt/ui/commit/814437255e47d6be40cd00420e2ab579ab76f5b9))
* **RadioGroup:** handle `value-key` prop ([850e84c](https://github.com/nuxt/ui/commit/850e84c0e0ce11bdc90be1ae652dec6723012243))
* **RadioGroup:** new component ([#41](https://github.com/nuxt/ui/issues/41)) ([e29b514](https://github.com/nuxt/ui/commit/e29b514f8d114a56eee76a29388fe050eb5c2722))
* **Select/SelectMenu:** handle `size` prop ([#133](https://github.com/nuxt/ui/issues/133)) ([b61696c](https://github.com/nuxt/ui/commit/b61696cdca77cc2f671dcbf330e731230ec97ba3))
* **SelectMenu:** add prop to disable search ([db30284](https://github.com/nuxt/ui/commit/db30284e7a24f14544c2c3b758c7912e98d3768a))
* **SelectMenu:** handle `multiple` prop ([27ffb8d](https://github.com/nuxt/ui/commit/27ffb8d8abc466d2a4bbb9a313b0c4f6a3a97501)), closes [#102](https://github.com/nuxt/ui/issues/102)
* **SelectMenu:** new component ([#103](https://github.com/nuxt/ui/issues/103)) ([7a376b5](https://github.com/nuxt/ui/commit/7a376b5e49baf11eb09c1b58326441cb240f7cb7))
* **Select:** new component ([#92](https://github.com/nuxt/ui/issues/92)) ([1942b8e](https://github.com/nuxt/ui/commit/1942b8e117bdae745049b088afe7487b6a9095f9))
* **Separator:** new component ([#46](https://github.com/nuxt/ui/issues/46)) ([8d76a8b](https://github.com/nuxt/ui/commit/8d76a8b1957d6910cdf25c66a966b808cf8525c7))
* **Skeleton:** new component ([e2fb253](https://github.com/nuxt/ui/commit/e2fb25309f13068c7a49de1b507f258013c72e11))
* **Slideover:** add `top` / `bottom` sides ([3e8a992](https://github.com/nuxt/ui/commit/3e8a99244e550f9ed68a30182c9ec0753d240138))
* **Slideover:** new component ([38eb932](https://github.com/nuxt/ui/commit/38eb932b538abb08d10e564308d92538ee345463))
* **Slideover:** open programmatically ([#122](https://github.com/nuxt/ui/issues/122)) ([b886150](https://github.com/nuxt/ui/commit/b886150147afbde882003fb5dc710a5975b633cd))
* **Slider:** new component ([#57](https://github.com/nuxt/ui/issues/57)) ([78e4560](https://github.com/nuxt/ui/commit/78e45600de9ac6a3e197baa7fed4fb4a46164c33))
* **Switch:** add ` label` and ` description` props ([#60](https://github.com/nuxt/ui/issues/60)) ([2fe91f3](https://github.com/nuxt/ui/commit/2fe91f3847198e4415edfda36cb977458866bbd9))
* **Switch:** form integration ([#48](https://github.com/nuxt/ui/issues/48)) ([ebb7c07](https://github.com/nuxt/ui/commit/ebb7c074afb583e6da8e1e06f12318faa1bf552c))
* **Switch:** handle `loading` and `loadingIcon` ([8fd3693](https://github.com/nuxt/ui/commit/8fd369372ba54d7ac2efa3d0186498d8e1608c41)), closes [#65](https://github.com/nuxt/ui/issues/65)
* **Switch:** new component ([cd1073d](https://github.com/nuxt/ui/commit/cd1073d93876c6f15f71bcd8d5c4c4bc76492330))
* **Tabs:** handle `avatar` ([bf0a04e](https://github.com/nuxt/ui/commit/bf0a04eb8bda666df2c88f7d0ea121c135f7d065))
* **Tabs:** handle `color` and `variant` props ([82ffc1e](https://github.com/nuxt/ui/commit/82ffc1ed574d741be03c43dfa300fefca0d042e0)), closes [#116](https://github.com/nuxt/ui/issues/116)
* **Tabs:** handle `content` prop as `boolean` ([e051ef6](https://github.com/nuxt/ui/commit/e051ef682aa7d4ec91b7145c1d96bb1d9913ad2d))
* **Tabs:** handle `size` prop ([#124](https://github.com/nuxt/ui/issues/124)) ([2b69652](https://github.com/nuxt/ui/commit/2b6965211dd9193026b85576d292f9f5138f99e6))
* **Tabs:** handle items `icon` ([06ea029](https://github.com/nuxt/ui/commit/06ea029ef624116792230fdb57cdcee13b610fc0))
* **Tabs:** new component ([13d389f](https://github.com/nuxt/ui/commit/13d389fd3979f089e37006741f51400168e58631))
* **Textarea:** new component ([#62](https://github.com/nuxt/ui/issues/62)) ([2ca6973](https://github.com/nuxt/ui/commit/2ca697333790efe3304f1f03b12be53912bdaf2d))
* **Toast:** actions `color` defaults from prop ([9a42338](https://github.com/nuxt/ui/commit/9a42338da377cc538fddad3c37143a6d74527a9b))
* **Toast:** add `actions` slot ([51872be](https://github.com/nuxt/ui/commit/51872bef6c7187450b63a4b88e4f6e714efd146a))
* **Toast:** implement progress duration ([d726e4d](https://github.com/nuxt/ui/commit/d726e4ddacc68c8bd63084bfbd32893e292d3846)), closes [#51](https://github.com/nuxt/ui/issues/51)
* **Toast:** new component ([#50](https://github.com/nuxt/ui/issues/50)) ([3da1e1a](https://github.com/nuxt/ui/commit/3da1e1a5183852011beadb91af4edbeb3f233e39))
* uniformize components sizes ([#68](https://github.com/nuxt/ui/issues/68)) ([f302a15](https://github.com/nuxt/ui/commit/f302a159727e44dce8f12909c3fbe316efe8b1e4))
* **useComponentIcons:** extract repetitive logic ([e4882e6](https://github.com/nuxt/ui/commit/e4882e6804394ab448dbdbb3673adadb80faafe2))
* **useKbd:** new composable ([#73](https://github.com/nuxt/ui/issues/73)) ([f076019](https://github.com/nuxt/ui/commit/f076019f8f84f2c71c66bfa806d7861ccf8fb959))
* **useToast:** add `clear` method ([89ff6b6](https://github.com/nuxt/ui/commit/89ff6b6702179fde2fff3294a1909463883378ae))
### Bug Fixes
* **Accordion:** dont set a `default-value` ([c36940a](https://github.com/nuxt/ui/commit/c36940a2210219aa36076b480740c044a536634f))
* **Accordion:** handle `disabled` through variants ([6236953](https://github.com/nuxt/ui/commit/6236953ed068721348f912b9033b1fa1beb378ab))
* **Alert:** add missing `close` slot ([26491af](https://github.com/nuxt/ui/commit/26491afcd10509f0f7d4cf8ea6e108f08f525f64))
* **Avatar:** bind `$attrs` on image ([da42c04](https://github.com/nuxt/ui/commit/da42c0489a501724e5bbcfedc76103df3d84f35d))
* **AvatarGroup:** default size to `md` ([9620d90](https://github.com/nuxt/ui/commit/9620d903c5471b76da3d7465d702d0e347c83892))
* **AvatarGroup:** handle deep children ([e9832b9](https://github.com/nuxt/ui/commit/e9832b95f56f97665be82ffe16e7cad72dc62f90))
* **Avatar:** improve sizes ([c726f13](https://github.com/nuxt/ui/commit/c726f13ac2a57a3de36d2c596d5a6ac086fa1a95))
* **Avatar:** increase gray on light mode ([fe467da](https://github.com/nuxt/ui/commit/fe467da9bfec5890bde8130832d4f89f954c84e8))
* **Badge:** handle `label` as `number` ([6cd7c8a](https://github.com/nuxt/ui/commit/6cd7c8a5fbe17c40610163258800f2034a2ba6ad))
* **Breadcrumb:** only apply `aria-current="page"` when link is active ([e5695e7](https://github.com/nuxt/ui/commit/e5695e78bc04827a1f774c4a39d9428eb31941e7))
* **Button:** extend now works with compound variants ([53755da](https://github.com/nuxt/ui/commit/53755da8359d8d5ffa4426b4f696489ebbe51f47))
* **ButtonGroup:** define its own `size` variant ([0dfd8b3](https://github.com/nuxt/ui/commit/0dfd8b3248d2f0fe6422ff4f03f027427282639b))
* **Button:** invalid icon size for `lg` ([f0f8927](https://github.com/nuxt/ui/commit/f0f89272a0992bdd1bba32e3458c864f665d5f58))
* **Button:** loading on trailing ([c8bdb51](https://github.com/nuxt/ui/commit/c8bdb51f68a308169f7ce10ede70612f968fa676))
* **Button:** move span with `truncate` inside default slot ([561c1fb](https://github.com/nuxt/ui/commit/561c1fb6652fe413497f8a04f563c1ed98f754ba))
* **Card:** improve body padding ([cecfb58](https://github.com/nuxt/ui/commit/cecfb58445affccf0d52f975d0329acbcbd3d9c2))
* **Card:** missing slots definition ([02da03b](https://github.com/nuxt/ui/commit/02da03b4a8fc9fd2c8d95a86812e746f789ebe1a))
* **Checkbox:** icon render ([fc50996](https://github.com/nuxt/ui/commit/fc50996ccfeaa2602f53c2f2683300462cf12992))
* **Checkbox:** reduce icon size ([3c89d6b](https://github.com/nuxt/ui/commit/3c89d6b2c5ad5cb0081c4607660760f7460a585e))
* **Chip:** extend now works with compound variants ([6dfd696](https://github.com/nuxt/ui/commit/6dfd696092e6a9633be62ec7d1a7fb2a24dc8657))
* **Chip:** improve sizes ([d5fe5b3](https://github.com/nuxt/ui/commit/d5fe5b3f4da1a834c14a6aae768163967c817a34))
* **Chip:** size injection ([#105](https://github.com/nuxt/ui/issues/105)) ([8baee12](https://github.com/nuxt/ui/commit/8baee1292f62ee7c4380ddb57b69bb9a23dbc2e0))
* **Collapsible:** ensure default slot exists ([c85a8cf](https://github.com/nuxt/ui/commit/c85a8cfe0b8f2e2b4a2ac15d3239c842b91b5bc0))
* **CommandPalette/InputMenu/Select/SelectMenu:** adapt chip size ([bdc3217](https://github.com/nuxt/ui/commit/bdc32175719b538828b4f63ad952dbd6f81b99b9))
* **CommandPalette:** ts errors ([d558b3e](https://github.com/nuxt/ui/commit/d558b3e29c6649bae2762c7412544d5d82b382bf))
* **components:** `ui` prop override with class ([#136](https://github.com/nuxt/ui/issues/136)) ([235556d](https://github.com/nuxt/ui/commit/235556d3e00b7a008fe16beba3f370b4af8bbb56))
* **components:** allow override of `root` through `ui.root` ([47ad74d](https://github.com/nuxt/ui/commit/47ad74d029f03c9013a76b8ee0a4b6cc37072cc5))
* **components:** declare `ui` prop with `PartialString` when arrays in theme slots ([5cc4457](https://github.com/nuxt/ui/commit/5cc4457a743fadbc775b11c41f7bb1fb89b5a728))
* **Container:** missing slots definition ([ab83053](https://github.com/nuxt/ui/commit/ab83053fef1571b0d0bf8519fb3c874b15cfef51))
* **ContextMenu/DropdownMenu:** move `open` and `default-open` props to `Sub` ([9af6d7d](https://github.com/nuxt/ui/commit/9af6d7dc5924f8c73036397e772fcbddf106e1af))
* **ContextMenu:** remove `arrow` prop ([4ac7a7e](https://github.com/nuxt/ui/commit/4ac7a7e3e97c28b0faf0cd1240f9aa6c385399ca))
* define empty props in slots for `nuxt-component-meta` parsing ([369e0b1](https://github.com/nuxt/ui/commit/369e0b195206277dbd8b39514f1bcb4a833512f3))
* **Divider:** add `w-full` only on horizontal wrapper ([#1565](https://github.com/nuxt/ui/issues/1565)) ([bd8b737](https://github.com/nuxt/ui/commit/bd8b737642280e6a83b67f9a27dd7a823a77e963))
* **DropdownMenu:** add overflow scroll if height is added ([80a8c2d](https://github.com/nuxt/ui/commit/80a8c2d772adf188eefa24dfdb1783bbb3fb98b7))
* **DropdownMenu:** handle disabled with data attribute for links ([cd214f9](https://github.com/nuxt/ui/commit/cd214f91dbe25828a99b26b8e908456743ae2cfc))
* **Dropdown:** missing `mouseenter` event on container ([7288953](https://github.com/nuxt/ui/commit/72889535e7e9763e7ebf59498f22c39bf09d6477))
* dynamic slots autocomplete ([#77](https://github.com/nuxt/ui/issues/77)) ([c6a93f7](https://github.com/nuxt/ui/commit/c6a93f71f2b0b9c2d3f89b1de2ae5ee254579ad0))
* **FormField:** added a utility type to fix some type errors ([#81](https://github.com/nuxt/ui/issues/81)) ([559a8cb](https://github.com/nuxt/ui/commit/559a8cba5814194b679de5beb3a66d5bda87e25b))
* **FormField:** allow `error` prop as boolean ([a23c314](https://github.com/nuxt/ui/commit/a23c3140dfef9bead862a4296a8cbfb05868a00e))
* **FormField:** generics ([a78b096](https://github.com/nuxt/ui/commit/a78b0965e8c936b315ac0e51d4955e28941f8a34))
* **Form:** inconsistent validation events for `InputMenu` and `Select` ([#123](https://github.com/nuxt/ui/issues/123)) ([a2114c5](https://github.com/nuxt/ui/commit/a2114c587435af901d5bbea047a297169bc7abfb))
* **fuse:** prevent indices highlight of a single char ([7b278b0](https://github.com/nuxt/ui/commit/7b278b041c4f09b512fc498a2eb54aef3cab845c))
* **Input/SelectMenu:** handle `file` type and `change` events ([#1570](https://github.com/nuxt/ui/issues/1570)) ([878f707](https://github.com/nuxt/ui/commit/878f7078a28c5e70a662682d1293db466d518c7d))
* **Input/Textarea:** remove useless gap ([67a1568](https://github.com/nuxt/ui/commit/67a15686e5adafbe5345253d06394f896e93e6f8))
* **Input:** invalid `xs` size ([4a281b3](https://github.com/nuxt/ui/commit/4a281b30939b0ccecbcfb213bb1102b21d959791))
* **InputMenu/Select/SelectMenu:** use `defuFn` to override base slot ([2aa4358](https://github.com/nuxt/ui/commit/2aa4358d328e7c8e1a1dca718acad391a09280fc))
* **InputMenu:** bind `searchTerm` with `defineModel` ([ff9fd9f](https://github.com/nuxt/ui/commit/ff9fd9f657c8e37a658136301ff4a1872842b956))
* **Input:** missing `file:` selector on dark mode ([f9259f6](https://github.com/nuxt/ui/commit/f9259f685777e5d6a5e5b5326e56579b24cf40d4))
* **Input:** use `pl` / `pr` instead of `ps` / `pe` ([a31d4cf](https://github.com/nuxt/ui/commit/a31d4cffb540db30a8689a170d941620bf4993c3)), closes [#32](https://github.com/nuxt/ui/issues/32)
* **Input:** use `ring` instead of `ring-1` ([0920099](https://github.com/nuxt/ui/commit/0920099362c9a2a8493a9715a9d84f4192d80a36))
* **Input:** wrong type for `type` prop ([3651c7e](https://github.com/nuxt/ui/commit/3651c7ec4135a05061b5aa613fa62867c2e0602f))
* **Kbd:** optional `value` prop when using default slot ([40d17f7](https://github.com/nuxt/ui/commit/40d17f7b03f2ce1306a8f3a9368744fbc1906ae1))
* **Link:** active class ([c384ec9](https://github.com/nuxt/ui/commit/c384ec94a2b5d4a7f92c98ce56c484e440a6afaf))
* **Link:** add missing `slots` definition ([76e3d0b](https://github.com/nuxt/ui/commit/76e3d0b9f3f582f84983f2813430e4d8eae40c84))
* **Link:** allow `ariaLabel` to be picked ([c1ac3a9](https://github.com/nuxt/ui/commit/c1ac3a9f9d5357bc3a7b125d8793d69d8d518bd3))
* **Link:** expose `active` instead of `isActive` in default slot ([46c066d](https://github.com/nuxt/ui/commit/46c066d79146bfad5ecc74769407b0f13595ec03))
* **Link:** improve `type` prop ([802a159](https://github.com/nuxt/ui/commit/802a15990d6c4c192c43730ceb46022fd19c7d61))
* **module:** add `isolate` class on root node ([0c6720b](https://github.com/nuxt/ui/commit/0c6720be7304af94dc3cb54fd772e40845875393))
* **module:** handle theme HMR on dev ([#84](https://github.com/nuxt/ui/issues/84)) ([12ba480](https://github.com/nuxt/ui/commit/12ba480d347f081bc0fac54e49b37b8f1513762f))
* **module:** inject options in `nuxt.options.ui` ([cf38e7e](https://github.com/nuxt/ui/commit/cf38e7ed78037001a159c794b097d2995a6d3f86))
* **module:** prevent `colors` option merge ([c4419fa](https://github.com/nuxt/ui/commit/c4419fa113c04c73e02c613a25fdbdde11cfbc32))
* **module:** prevent override of `rootAttrs.class` ([3097da4](https://github.com/nuxt/ui/commit/3097da486fe0891641d81fefcd38d9b31284a8b0))
* **module:** typo in `fuchsia` color ([7fd38a8](https://github.com/nuxt/ui/commit/7fd38a8cb829c1f19a7da2f80f2a1cc4f1ca257e))
* **module:** use `@tailwindcss/postcss` ([cdf6ebd](https://github.com/nuxt/ui/commit/cdf6ebdafbf3174d27b8a3a29c22df2f5160ac51))
* **module:** use relative imports to components / composables ([42f4f8d](https://github.com/nuxt/ui/commit/42f4f8d3370ab0dd94e09d8960e87076afbb1035))
* **NavigationMenu:** `highlightColor` defaults to `color` prop ([0bdd6df](https://github.com/nuxt/ui/commit/0bdd6dfe8609d1c951023b6785c4ff87a813b2f6))
* **NavigationMenu:** `label` doesn't need to be typed as `number` ([ee1d6ed](https://github.com/nuxt/ui/commit/ee1d6ed08fdcf00ad11ea2ef15869b861ae8a688))
* **NavigationMenu:** add default `highlightColor` ([c838b3a](https://github.com/nuxt/ui/commit/c838b3a040d090aeeab297fca451ea8d80942728))
* **NavigationMenu:** handle `disabled` through variants + `isolate` list + use separator instead of divide ([f664f69](https://github.com/nuxt/ui/commit/f664f690970058088ebfa975297ca2721c03316f))
* **NavigationMenu:** handle `truncate` on vertical orientation ([298ac68](https://github.com/nuxt/ui/commit/298ac68447046a0a37d1857db24fe815cc02fbab))
* **NavigationMenu:** optional `links` ([4301821](https://github.com/nuxt/ui/commit/4301821473b0cca086e634146cc6d9f440ca151b))
* **NavigationMenu:** prevent err without links ([03edad8](https://github.com/nuxt/ui/commit/03edad885d082a38688e0d34efe12c3f86fc0291))
* **NavigationMenu:** use `ULink` with `custom` ([c8bedf8](https://github.com/nuxt/ui/commit/c8bedf84585ad119599a89faa23185a1b94120da))
* **Pagination:** center text when link ([440593c](https://github.com/nuxt/ui/commit/440593c5e43eac3ede2acf257e1862a648b02d40))
* **plugins:** add missing `type` ([63f752a](https://github.com/nuxt/ui/commit/63f752a4a8e4a5966bbe938e65dfdf706c706a07))
* **plugins:** use `import.meta` ([c9f0999](https://github.com/nuxt/ui/commit/c9f09992b7ac9ef2c34d5957fb31fd2aa5db3791))
* **Popover:** ensure default slot exists ([5d3ad6b](https://github.com/nuxt/ui/commit/5d3ad6b93ef5fa583a5dcbee102a7391426308f3))
* **Popover:** missing `mouseenter` event on container ([8517897](https://github.com/nuxt/ui/commit/8517897c34adaa9e3624f867b43106deb59fcbe8)), closes [#1564](https://github.com/nuxt/ui/issues/1564)
* **Popover:** split reactive props with `mode` ([7d2d3b9](https://github.com/nuxt/ui/commit/7d2d3b9c0ffc4e58021639e8b7ea0d23addb4493))
* **Popover:** use `scale-in` / `scale-out` animations ([f90f7d7](https://github.com/nuxt/ui/commit/f90f7d7b7c0d81cf42b2232e9c12597210cd5791))
* **Progress:** initial indicator style when percent is 0 ([d2442a1](https://github.com/nuxt/ui/commit/d2442a1e4793d3869bfc938197b00f21b4033d19))
* **RadioGroup:** missing `as` prop binding ([d3c7991](https://github.com/nuxt/ui/commit/d3c79912d8b9c02fee267958cd34e4fbeb0d3de7))
* **RadioGroup:** style `legend` based on size ([b1bcaab](https://github.com/nuxt/ui/commit/b1bcaabd19eb3087d222dc53a37a520735b2f4ed))
* remove `IconProps` usage ([6d377d1](https://github.com/nuxt/ui/commit/6d377d1f4bb0b29f9bec346a31dbfb29fbdc57fe))
* **SelectMenu:** adapt input size ([5c12d42](https://github.com/nuxt/ui/commit/5c12d428c4e39a5c28b5d0107c0091f8299bca50))
* **SelectMenu:** display `modelValue` even if false ([813fdfd](https://github.com/nuxt/ui/commit/813fdfd646dd4f2cb574653dc6a4e993f5025e10))
* **SelectMenu:** input before empty ([bedb863](https://github.com/nuxt/ui/commit/bedb863fc68fd8b687a5094aa16da6aed21b5959))
* **Select:** missing comma in `&nbsp;` ([c00ec5e](https://github.com/nuxt/ui/commit/c00ec5e2f255d83296cfd71f991cca04b00bfa26))
* **Select:** wrong button group variants ([5b2e7d8](https://github.com/nuxt/ui/commit/5b2e7d8bad6531795c00cdaa37e21d769dee452e))
* **Skeleton:** increase gray on light mode ([3cdbb27](https://github.com/nuxt/ui/commit/3cdbb276357a2a167079507975b285f9c714462f))
* specify pnpm version ([#85](https://github.com/nuxt/ui/issues/85)) ([e5f0063](https://github.com/nuxt/ui/commit/e5f0063dbac29f7d27d8ad5a3d42a4c7ee71dcab))
* **Switch:** improve sizes ([3a89661](https://github.com/nuxt/ui/commit/3a89661c663998b1de440f3f9925564434b43f2e))
* **Tabs:** `force-mount` content ([d294931](https://github.com/nuxt/ui/commit/d2949310eeeea323b1d066f2ccf34b7597b12e32))
* **Tabs:** `horizontal` orientation ([1e65933](https://github.com/nuxt/ui/commit/1e65933d9ca12b91b24e58ddd1273848fe11057c))
* **Tabs:** add missing slots definition ([b78ca9c](https://github.com/nuxt/ui/commit/b78ca9c56a60941d6a2a1d1c6e2234fbc5980e7d))
* **Tabs:** align `link` variant left when vertical ([9d5f9a7](https://github.com/nuxt/ui/commit/9d5f9a70101bcc75f05dc59a3d4dc2d368106b5f))
* **Tabs:** broken design ([80a3a0c](https://github.com/nuxt/ui/commit/80a3a0c28f81656b8c144146b72ceca45d2e99b7))
* **Tabs:** improve config ([88eb4ca](https://github.com/nuxt/ui/commit/88eb4cac974194b13a34281f76d4771f125685a2))
* **Tabs:** missing props pick ([f086f26](https://github.com/nuxt/ui/commit/f086f2662e659e5522adcfbad453d4f44b9be9d1))
* **Tabs:** optional `items` ([20caea1](https://github.com/nuxt/ui/commit/20caea1cd7b896e443c846766865174234a25d20))
* **Tabs:** specific transition ([48ddf39](https://github.com/nuxt/ui/commit/48ddf39188467b3c4d346c22c0a60e4acd4b025d))
* **Tabs:** use `shrink-0` ([f8b50a3](https://github.com/nuxt/ui/commit/f8b50a357152a600ccab784796d8cf11e1eb039d))
* **Tabs:** use `transition-all` ([92e1d09](https://github.com/nuxt/ui/commit/92e1d09990d88ed43eec74d313f76a1c2b7eb565))
* **Tabs:** wrong text color with `pill` colored ([f70b639](https://github.com/nuxt/ui/commit/f70b63970a9791533f7ae29dfc56a12001119e2d))
* **templates:** add `error` in `AppConfig` type ([c7536a7](https://github.com/nuxt/ui/commit/c7536a7af963319ed6307701b38ff2b006b2a3ac))
* **templates:** dont override `AppConfig` type ([e151be4](https://github.com/nuxt/ui/commit/e151be4734d8c9a53cf33f6040994912cce24a67))
* **templates:** export types in dev mode ([1eaec0f](https://github.com/nuxt/ui/commit/1eaec0ff568bcdff78a0aae0fa824f8b7d1c63e6))
* **templates:** handle `-` in regexp ([0a00387](https://github.com/nuxt/ui/commit/0a00387688923fc0cfacbd70c335c664d8d04cc0))
* **templates:** import from `[#build](https://github.com/nuxt/ui/issues/build)/ui.css` no longer works ([eb85fa8](https://github.com/nuxt/ui/commit/eb85fa8353ac791b4c889ec103c7247e60bfd81a))
* **templates:** missing command in keyframes ([6a1b97a](https://github.com/nuxt/ui/commit/6a1b97add00e481bcc6b06d46e17f4d4f6a97468))
* **templates:** pass options to theme in dev mode ([5694823](https://github.com/nuxt/ui/commit/5694823a416fbb70d10702a023420837d31046d6))
* **templates:** unshift css ([e1ab903](https://github.com/nuxt/ui/commit/e1ab9031097d96f0459621c677e1522c49f9297d))
* **Textarea:** invalid `xs` size ([bed6252](https://github.com/nuxt/ui/commit/bed62520a988cc2e9337d3eb72f2e512df40cf14))
* **Textarea:** same `size` as input ([e398637](https://github.com/nuxt/ui/commit/e398637174008cc1bcb8519169bc3c539157cbae))
* **Toast:** add missing slots ([cfb4cfd](https://github.com/nuxt/ui/commit/cfb4cfdd7b81302fb3c3f9cd4b4e3a7c80e28779))
* **Toaster:** add missing transition on `translate` ([239e0a5](https://github.com/nuxt/ui/commit/239e0a5ac1315a37b52a16bb7a024cefa28dac23))
* **Toaster:** increase container height to prevent animation blink ([4dcb74e](https://github.com/nuxt/ui/commit/4dcb74e0a9feea074c6cb56aa73a28107deddc38))
* **Toaster:** proxy slot from `App` ([4b29828](https://github.com/nuxt/ui/commit/4b29828e9ddb2602ad7195a4c21ea7963377248e))
* **Toaster:** wrong leave animation when collapsed ([c3ed18b](https://github.com/nuxt/ui/commit/c3ed18beb64369fe8a5e0ffee0b749f40c9fc736))
* **Toast:** prevent progress bar to blink on leave ([83049fd](https://github.com/nuxt/ui/commit/83049fd23ed4eb829a64061a08be846aefab4b98))
* **Tooltip:** ensure default slot exists ([431255e](https://github.com/nuxt/ui/commit/431255e0fec90555f1b5e8e0fc1f039ed853eb75))
* **Tooltip:** missing conditions on slots ([d00084c](https://github.com/nuxt/ui/commit/d00084c54cebe239f738af0bfdc159124bb85903))
* **Tooltip:** missing root props proxy ([be8bf69](https://github.com/nuxt/ui/commit/be8bf691c3883845582b788b15c99be7fabb3c29))
* **Tooltip:** put back close animation ([34cf395](https://github.com/nuxt/ui/commit/34cf395f1a688404030c2a5f37417fae9b2f38d9))
* **Tooltip:** remove content max-width ([6c5354e](https://github.com/nuxt/ui/commit/6c5354edde42f51cc1c642c2ae5b17ea0886dae2))
* **Tooltip:** use `scale-in` / `scale-out` animations ([0450f6b](https://github.com/nuxt/ui/commit/0450f6b4a91d0af38ff6094fb590915b7164d9e0))
* **types:** useless import ([5f7872f](https://github.com/nuxt/ui/commit/5f7872f06e81e03443e2d1c27a654cfe32c55fb3))
* **useComponentIcons:** reactivity when using `defu` ([45454fa](https://github.com/nuxt/ui/commit/45454fae45b8571a9691284bd6a13a838e8ea1c9))
## [2.18.6](https://github.com/nuxt/ui/compare/v2.18.5...v2.18.6) (2024-09-23)
### Bug Fixes
* **components:** accept partial config in `ui` prop ([#2235](https://github.com/nuxt/ui/issues/2235)) ([eecf4f7](https://github.com/nuxt/ui/commit/eecf4f7ed8a32a874f00afd7bff2964a1366e0b5))
* **Modal/Slideover:** bind transition class to `TransitionChild` for Vue 3.5 ([#2227](https://github.com/nuxt/ui/issues/2227)) ([803c20a](https://github.com/nuxt/ui/commit/803c20ad92e8a31fefd6d300856735b0e9adbdf9))
* **SelectMenu:** wrong placeholder color with multiple ([#2218](https://github.com/nuxt/ui/issues/2218)) ([28ad5cf](https://github.com/nuxt/ui/commit/28ad5cf98251c6a8acec8d0bf4f0fd07ff6b7066))
* **Table:** colspan with expand ([#2217](https://github.com/nuxt/ui/issues/2217)) ([56118c4](https://github.com/nuxt/ui/commit/56118c4a794f3d763dad7b65e044814cf7ef11cf))
* **Tabs:** handle icon `margin` in RTL mode ([#2233](https://github.com/nuxt/ui/issues/2233)) ([ea05414](https://github.com/nuxt/ui/commit/ea05414930fe3f5e6805c8aa25bbe8f746bcc86e))
* **useFormField:** optional property access ([#2226](https://github.com/nuxt/ui/issues/2226)) ([0a054a5](https://github.com/nuxt/ui/commit/0a054a52b64b4f774041c40223e18e7e056cfd80))
## [2.18.5](https://github.com/nuxt/ui/compare/v2.18.4...v2.18.5) (2024-09-18)
### Features
* **Form:** add errors slot prop ([#2188](https://github.com/nuxt/ui/issues/2188)) ([67c6a74](https://github.com/nuxt/ui/commit/67c6a74ed15db1ee8a40e9c74ecfef0d3c3e374a))
### Bug Fixes
* **Button:** button link not showing disabled classes ([#2185](https://github.com/nuxt/ui/issues/2185)) ([e8ea84a](https://github.com/nuxt/ui/commit/e8ea84a5736759d953664f8f397a2339c212b294))
* **Carousel:** remove trailing space in next button icon ([#2088](https://github.com/nuxt/ui/issues/2088)) ([1282a5f](https://github.com/nuxt/ui/commit/1282a5f6c001aa05597d458800bafcf6b6419634))
* **FormGroup:** remove id when used with `RadioGroup` ([#2152](https://github.com/nuxt/ui/issues/2152)) ([7aec42c](https://github.com/nuxt/ui/commit/7aec42ca15aaa0ccc63c520b484cba203fd3232b))
* **Input:** avoid binding value when type is `file` ([#2047](https://github.com/nuxt/ui/issues/2047)) ([82313e8](https://github.com/nuxt/ui/commit/82313e862cbf21ae631156af4cd057f1383db634))
* **module:** allow CSS variables in tailwind colors ([#2014](https://github.com/nuxt/ui/issues/2014)) ([7f50c70](https://github.com/nuxt/ui/commit/7f50c7031fecb5ab26a6d0f58b576b2fd0860487))
* **module:** augment `@nuxt/schema` rather than `nuxt/schema` ([#2171](https://github.com/nuxt/ui/issues/2171)) ([ead904f](https://github.com/nuxt/ui/commit/ead904fd2f2bbb29fd60ccde063bf02daa2cbdbb))
* **module:** consider user tailwind `configPath` for module as string ([#2074](https://github.com/nuxt/ui/issues/2074)) ([e4ba4f7](https://github.com/nuxt/ui/commit/e4ba4f7c729f99dde51891636605793864812d30))
* **Pagination:** use links on prev and next button ([#2179](https://github.com/nuxt/ui/issues/2179)) ([c850f85](https://github.com/nuxt/ui/commit/c850f85aaa40c7abbe8cc4dc1bd4705bf7677390))
* **README:** update license link ([#2154](https://github.com/nuxt/ui/issues/2154)) ([8d79eea](https://github.com/nuxt/ui/commit/8d79eea19b3276b1f1e069d33b98b311e9b91cfd))
* **Slideover:** bind `rounded` class to panel ([#2187](https://github.com/nuxt/ui/issues/2187)) ([bf32baa](https://github.com/nuxt/ui/commit/bf32baaab01dc4150622f67b3b4a8d02d21b922c))
* **Slideover:** bind `shadow` class to panel ([#2201](https://github.com/nuxt/ui/issues/2201)) ([d22526c](https://github.com/nuxt/ui/commit/d22526c0c10735a92e63b7d086e7b8534a08d768))
* **Table:** checkbox can emit the `[@select](https://github.com/select)` event ([#2072](https://github.com/nuxt/ui/issues/2072)) ([b1f691f](https://github.com/nuxt/ui/commit/b1f691f28ca8c94f6b658dcb61eeff06951bd1d0))
* **Table:** select all rows reactivity issue ([#2200](https://github.com/nuxt/ui/issues/2200)) ([68124de](https://github.com/nuxt/ui/commit/68124de5106e55cb2987a6ba4ec1120d79b51788))
* **Tabs:** recalculate marker if items change ([#2101](https://github.com/nuxt/ui/issues/2101)) ([82c4926](https://github.com/nuxt/ui/commit/82c4926c090ce7fac48022a93b1b05b877bb48dd))
* **Textarea:** resolve row count calculation errors caused by scrollbar ([#2040](https://github.com/nuxt/ui/issues/2040)) ([8210936](https://github.com/nuxt/ui/commit/8210936f22fcf6b7eb5b9711e2c29be38956b8d6))
## [2.18.4](https://github.com/nuxt/ui/compare/v2.18.3...v2.18.4) (2024-08-05)
### Bug Fixes
* **Form:** submit event data ([#2012](https://github.com/nuxt/ui/issues/2012)) ([4d61936](https://github.com/nuxt/ui/commit/4d61936e7e90b664846a8f265825612c509511d7))
* **module:** handle nested colors from ui config ([#2008](https://github.com/nuxt/ui/issues/2008)) ([1cc7e2a](https://github.com/nuxt/ui/commit/1cc7e2a306e0f3f666b9a588f6ed02e7eabc0272))
* **module:** reduce css bundle size by fixing safelist regex ([#2005](https://github.com/nuxt/ui/issues/2005)) ([8ac9ca4](https://github.com/nuxt/ui/commit/8ac9ca49789a9a7281f7a40926e7e9a8068cc395))
* **module:** suffix types imports with `/index` ([7e37668](https://github.com/nuxt/ui/commit/7e37668940d06c5aa20b60d9bfd600d50a171014)), closes [#2018](https://github.com/nuxt/ui/issues/2018)
* **Tabs:** use `nextTick` before marker calc ([#2020](https://github.com/nuxt/ui/issues/2020)) ([9c04969](https://github.com/nuxt/ui/commit/9c049690227af8aba61a1f7c002b00c5dfeb63ff))
* **useFormGroup:** app config default input size ([#2011](https://github.com/nuxt/ui/issues/2011)) ([3485092](https://github.com/nuxt/ui/commit/3485092edb55f9ef2ca038a8c137431866d6c28a))
## [2.18.3](https://github.com/nuxt/ui/compare/v2.18.2...v2.18.3) (2024-07-30)

140
README.md
View File

@@ -1,4 +1,4 @@
[![nuxt-ui.png](https://repository-images.githubusercontent.com/428329515/43fec891-9030-4601-8233-5d45ba5c6013)](https://ui.nuxt.com)
[![nuxt-ui.png](https://volta.s3.fr-par.scw.cloud/nuxt_ui_social_card_531d133fa2.png)](https://ui.nuxt.com)
# Nuxt UI
@@ -7,77 +7,115 @@
[![License][license-src]][license-href]
[![Nuxt][nuxt-src]][nuxt-href]
Nuxt UI is a module that provides a set of Vue components and composables built with [Tailwind CSS](https://tailwindcss.com/) and [Headless UI](https://headlessui.dev/) to help you build beautiful and accessible user interfaces.
We're thrilled to introduce Nuxt UI v3, a significant upgrade to our UI library that delivers extensive improvements and robust new capabilities. This major update harnesses the combined strengths of [Reka UI](https://reka-ui.com/), [Tailwind CSS v4](https://tailwindcss.com/docs/v4-beta), and [Tailwind Variants](https://www.tailwind-variants.org/) to offer developers an unparalleled set of tools for creating sophisticated, accessible, and highly performant user interfaces.
Its goal is to provide everything related to UI when building a Nuxt app. This includes components, icons, colors, dark mode but also keyboard shortcuts.
## Features
- Built with [Headless UI](https://headlessui.dev/) and [Tailwind CSS](https://tailwindcss.com/)
- HMR support through Nuxt App Config
- Dark mode support
- Support for LTR and RTL languages
- Keyboard shortcuts
- Bundled icons
- Fully typed
- [Figma Kit](https://www.figma.com/community/file/1288455405058138934)
Read more on [ui.nuxt.com](https://ui.nuxt.com)
## Installation
```bash
npx nuxi@latest module add ui
```
If you want latest updates, please use `@nuxt/ui-edge` in your `package.json`:
```json
{
"devDependencies": {
"@nuxt/ui": "npm:@nuxt/ui-edge@latest"
}
}
```
> [!NOTE]
> You are on the `v3` development branch, check out the [dev branch](https://github.com/nuxt/ui) for Nuxt UI v2.
## Documentation
Visit https://ui.nuxt.com to explore the documentation.
Visit https://ui3.nuxt.dev to explore the documentation.
## Installation
```bash [pnpm]
pnpm add @nuxt/ui@next
```
```bash [yarn]
yarn add @nuxt/ui@next
```
```bash [npm]
npm install @nuxt/ui@next
```
```bash [bun]
bun add @nuxt/ui@next
```
### Nuxt
1. Add the Nuxt UI module in your `nuxt.config.ts`:
```ts [nuxt.config.ts]
export default defineNuxtConfig({
modules: ['@nuxt/ui']
})
```
2. Import Tailwind CSS and Nuxt UI in your CSS:
```css [assets/css/main.css]
@import "tailwindcss";
@import "@nuxt/ui";
```
Learn more in the [installation guide](https://ui3.nuxt.dev/getting-started/installation/nuxt).
### Vue
1. Add the Nuxt UI Vite plugin in your `vite.config.ts`:
```ts [vite.config.ts]
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import ui from '@nuxt/ui/vite'
export default defineConfig({
plugins: [
vue(),
ui()
]
})
```
2. Use the Nuxt UI Vue plugin in your `main.ts`:
```ts [main.ts]
import { createApp } from 'vue'
import ui from '@nuxt/ui/vue-plugin'
import App from './App.vue'
const app = createApp(App)
app.use(ui)
app.mount('#app')
```
3. Import Tailwind CSS and Nuxt UI in your CSS:
```css [assets/main.css]
@import "tailwindcss";
@import "@nuxt/ui";
```
Learn more in the [installation guide](https://ui3.nuxt.dev/getting-started/installation/vue).
## Credits
- [nuxt/nuxt](https://github.com/nuxt/nuxt)
- [nuxt/icon](https://github.com/nuxt/icon)
- [nuxt/fonts](https://github.com/nuxt/fonts)
- [nuxt-modules/color-mode](https://github.com/nuxt-modules/color-mode)
- [nuxt-modules/tailwindcss](https://github.com/nuxt-modules/tailwindcss)
- [unovue/reka-ui](https://github.com/unovue/reka-ui)
- [tailwindlabs/tailwindcss](https://github.com/tailwindlabs/tailwindcss)
- [tailwindlabs/headlessui](https://github.com/tailwindlabs/headlessui)
- [vueuse/vueuse](https://github.com/vueuse/vueuse)
- [egoist/tailwindcss-icons](https://github.com/egoist/tailwindcss-icons)
## Contributing
Thank you for considering contributing to Nuxt UI. Here are a few ways you can get involved:
- Reporting Bugs: If you come across any bugs or issues, please check out the reporting bugs guide to learn how to submit a bug report.
- Suggestions: Have any thoughts to enhance Nuxt UI? We'd love to hear them! Check out the [contribution guide](https://ui.nuxt.com/getting-started/contributing) to share your suggestions.
## Local Development
Follow the docs to [Set up your local development environment](https://ui.nuxt.com/getting-started/contributing#_2-local-development-setup) and contribute.
## License
Licensed under the [MIT license](https://github.com/nuxt/ui/blob/dev/LICENSE.md).
Licensed under the [MIT license](https://github.com/nuxt/ui/blob/v3/LICENSE.md).
<!-- Badges -->
[npm-version-src]: https://img.shields.io/npm/v/@nuxt/ui/latest.svg?style=flat&colorA=18181B&colorB=28CF8D
[npm-version-src]: https://img.shields.io/npm/v/@nuxt/ui/next.svg?style=flat&colorA=18181B&colorB=28CF8D
[npm-version-href]: https://npmjs.com/package/@nuxt/ui
[npm-downloads-src]: https://img.shields.io/npm/dm/@nuxt/ui.svg?style=flat&colorA=18181B&colorB=28CF8D
[npm-downloads-href]: https://npmjs.com/package/@nuxt/ui
[npm-downloads-href]: https://npm.chart.dev/@nuxt/ui
[license-src]: https://img.shields.io/github/license/nuxt/ui.svg?style=flat&colorA=18181B&colorB=28CF8D
[license-href]: https://github.com/nuxt/ui/blob/main/LICENSE
[license-href]: https://github.com/nuxt/ui/blob/v3/LICENSE.md
[nuxt-src]: https://img.shields.io/badge/Nuxt-18181B?logo=nuxt.js
[nuxt-href]: https://nuxt.com

24
build.config.ts Normal file
View File

@@ -0,0 +1,24 @@
import { defineBuildConfig } from 'unbuild'
export default defineBuildConfig({
entries: [
// Include devtools runtime files
{ input: './src/devtools/runtime', builder: 'mkdist', outDir: 'dist/devtools/runtime' },
// Vue support
'./src/unplugin',
'./src/vite'
],
rollup: {
emitCJS: true
},
replace: {
'process.env.DEV': 'false',
'process.env.NUXT_UI_DEVTOOLS_LOCAL': 'false'
},
hooks: {
'mkdist:entry:options'(ctx, entry, options) {
options.addRelativeDeclarationExtensions = false
}
},
externals: ['#build/ui', 'vite']
})

View File

@@ -0,0 +1,83 @@
import { existsSync, promises as fsp } from 'node:fs'
import { resolve } from 'pathe'
import { defineCommand } from 'citty'
import { consola } from 'consola'
import { splitByCase, upperFirst, camelCase, kebabCase } from 'scule'
import { appendFile, sortFile } from '../../utils.mjs'
import templates from '../../templates.mjs'
export default defineCommand({
meta: {
name: 'component',
description: 'Make a new component.'
},
args: {
name: {
type: 'positional',
required: true,
description: 'Name of the component.'
},
primitive: {
type: 'boolean',
description: 'Create a primitive component.'
},
pro: {
type: 'boolean',
description: 'Create a pro component.'
},
prose: {
type: 'boolean',
description: 'Create a prose component (with --pro).'
},
content: {
type: 'boolean',
description: 'Create a content component (with --pro).'
}
},
async setup({ args }) {
const name = args.name
if (!name) {
consola.error('`name` argument is missing!')
process.exit(1)
}
if (args.prose && !args.pro) {
consola.error('`--prose` flag can only be used with `--pro` flag!')
process.exit(1)
}
if (args.content && !args.pro) {
consola.error('`--content` flag can only be used with `--pro` flag!')
process.exit(1)
}
const path = resolve('.')
for (const template of Object.keys(templates)) {
const { filename, contents } = templates[template](args)
if (!contents) {
continue
}
const filePath = resolve(path, filename)
if (existsSync(filePath)) {
consola.error(`🚨 ${filePath} already exists!`)
continue
}
await fsp.writeFile(filePath, contents.trim() + '\n')
consola.success(`🪄 Generated ${filePath}!`)
}
const themePath = resolve(path, `src/theme/${args.prose ? 'prose/' : ''}${args.content ? 'content/' : ''}index.ts`)
await appendFile(themePath, `export { default as ${camelCase(name)} } from './${kebabCase(name)}'`)
await sortFile(themePath)
if (!args.prose) {
const typesPath = resolve(path, 'src/runtime/types/index.ts')
await appendFile(typesPath, `export * from '../components/${args.content ? 'content/' : ''}${splitByCase(name).map(p => upperFirst(p)).join('')}.vue'`)
await sortFile(typesPath)
}
}
})

View File

@@ -0,0 +1,14 @@
import { defineCommand } from 'citty'
import component from './component.mjs'
import locale from './locale.mjs'
export default defineCommand({
meta: {
name: 'make',
description: 'Commands to create new Nuxt UI entities.'
},
subCommands: {
component,
locale
}
})

View File

@@ -0,0 +1,64 @@
import { existsSync, promises as fsp } from 'node:fs'
import { resolve } from 'pathe'
import { consola } from 'consola'
import { appendFile, sortFile, normalizeLocale } from '../../utils.mjs'
import { defineCommand } from 'citty'
export default defineCommand({
meta: {
name: 'locale',
description: 'Make a new locale.'
},
args: {
code: {
description: 'Locale code to create. For example: en.',
required: true
},
name: {
description: 'Locale name to create. For example: English.',
required: true
},
dir: {
description: 'Locale direction. For example: rtl.',
default: 'ltr'
}
},
async setup({ args }) {
const path = resolve('.')
const localePath = resolve(path, `src/runtime/locale`)
const originLocaleFilePath = resolve(localePath, 'en.ts')
const newLocaleFilePath = resolve(localePath, `${args.code}.ts`)
// Validate locale code
if (existsSync(newLocaleFilePath)) {
consola.error(`🚨 ${args.code} already exists!`)
process.exit(1)
}
if (!['ltr', 'rtl'].includes(args.dir)) {
consola.error(`🚨 Direction ${args.dir} not supported!`)
process.exit(1)
}
if (!args.code.match(/^[a-z]{2}(?:_[a-z]{2,4})?$/)) {
consola.error(`🚨 ${args.code} is not a valid locale code!\nExample: en or en_us`)
process.exit(1)
}
// Create new locale export
const localeExportFile = resolve(localePath, `index.ts`)
await appendFile(localeExportFile, `export { default as ${args.code} } from './${args.code}'`)
await sortFile(localeExportFile)
// Create new locale file
await fsp.copyFile(originLocaleFilePath, newLocaleFilePath)
const localeFile = await fsp.readFile(newLocaleFilePath, 'utf-8')
const rewrittenLocaleFile = localeFile
.replace(/name: '(.*)',/, `name: '${args.name}',`)
.replace(/code: '(.*)',/, `code: '${normalizeLocale(args.code)}',${(args.dir && args.dir !== 'ltr') ? `\n dir: '${args.dir}',` : ''}`)
await fsp.writeFile(newLocaleFilePath, rewrittenLocaleFile)
consola.success(`🪄 Generated ${newLocaleFilePath}`)
}
})

15
cli/index.mjs Executable file
View File

@@ -0,0 +1,15 @@
#!/usr/bin/env node
import { defineCommand, runMain } from 'citty'
import make from './commands/make/index.mjs'
const main = defineCommand({
meta: {
name: 'nuxt-ui',
description: 'Nuxt UI CLI'
},
subCommands: {
make
}
})
runMain(main)

13
cli/package.json Normal file
View File

@@ -0,0 +1,13 @@
{
"name": "@nuxt/ui-cli",
"type": "module",
"exports": {
".": "./index.mjs"
},
"dependencies": {
"citty": "^0.1.6",
"consola": "^3.2.3",
"pathe": "^1.1.2",
"scule": "^1.3.0"
}
}

216
cli/templates.mjs Normal file
View File

@@ -0,0 +1,216 @@
import { splitByCase, upperFirst, camelCase, kebabCase } from 'scule'
const playground = ({ name, pro }) => {
const upperName = splitByCase(name).map(p => upperFirst(p)).join('')
const kebabName = kebabCase(name)
return {
filename: `playground/app/pages/components/${kebabName}.vue`,
contents: pro
? undefined
: `
<template>
<div>
<U${upperName} />
</div>
</template>
`
}
}
const component = ({ name, primitive, pro, prose, content }) => {
const upperName = splitByCase(name).map(p => upperFirst(p)).join('')
const camelName = camelCase(name)
const kebabName = kebabCase(name)
const key = pro ? 'uiPro' : 'ui'
const path = pro ? 'ui-pro' : 'ui'
return {
filename: `src/runtime/components/${prose ? 'prose/' : ''}${content ? 'content/' : ''}${upperName}.vue`,
contents: primitive
? `
<script lang="ts">
import { tv } from 'tailwind-variants'
import type { AppConfig } from '@nuxt/schema'
import _appConfig from '#build/app.config'
import theme from '#build/${path}/${prose ? 'prose/' : ''}${content ? 'content/' : ''}${kebabName}'
const appConfig = _appConfig as AppConfig & { ${key}: { ${prose ? 'prose: { ' : ''}${camelName}: Partial<typeof theme> } }${prose ? ' }' : ''}
const ${camelName} = tv({ extend: tv(theme), ...(appConfig.${key}?.${prose ? 'prose?.' : ''}${camelName} || {}) })
export interface ${upperName}Props {
/**
* The element or component this component should render as.
* @defaultValue 'div'
*/
as?: any
class?: any
ui?: Partial<typeof ${camelName}.slots>
}
export interface ${upperName}Slots {
default(props?: {}): any
}
</script>
<script setup lang="ts">
import { Primitive } from 'reka-ui'
const props = withDefaults(defineProps<${upperName}Props>(), { as: 'div' })
defineSlots<${upperName}Slots>()
const ui = ${camelName}()
</script>
<template>
<Primitive :as="as" :class="ui.root({ class: [props.class, props.ui?.root] })">
<slot />
</Primitive>
</template>
`
: `
<script lang="ts">
import { tv, type VariantProps } from 'tailwind-variants'
import type { ${upperName}RootProps, ${upperName}RootEmits } from 'reka-ui'
import type { AppConfig } from '@nuxt/schema'
import _appConfig from '#build/app.config'
import theme from '#build/${path}/${prose ? 'prose/' : ''}${content ? 'content/' : ''}${kebabName}'
const appConfig = _appConfig as AppConfig & { ${key}: { ${prose ? 'prose: { ' : ''}${camelName}: Partial<typeof theme> } }${prose ? ' }' : ''}
const ${camelName} = tv({ extend: tv(theme), ...(appConfig.${key}?.${prose ? 'prose?.' : ''}${camelName} || {}) })
type ${upperName}Variants = VariantProps<typeof ${camelName}>
export interface ${upperName}Props extends Pick<${upperName}RootProps> {
class?: any
ui?: Partial<typeof ${camelName}.slots>
}
export interface ${upperName}Emits extends ${upperName}RootEmits {}
export interface ${upperName}Slots {}
</script>
<script setup lang="ts">
import { ${upperName}Root, useForwardPropsEmits } from 'reka-ui'
import { reactivePick } from '@vueuse/core'
const props = defineProps<${upperName}Props>()
const emits = defineEmits<${upperName}Emits>()
const slots = defineSlots<${upperName}Slots>()
const rootProps = useForwardPropsEmits(reactivePick(props), emits)
const ui = ${camelName}()
</script>
<template>
<${upperName}Root v-bind="rootProps" :class="ui.root({ class: [props.class, props.ui?.root] })" />
</template>
`
}
}
const theme = ({ name, prose, content }) => {
const kebabName = kebabCase(name)
return {
filename: `src/theme/${prose ? 'prose/' : ''}${content ? 'content/' : ''}${kebabName}.ts`,
contents: prose
? `
export default {
base: ''
}
`
: `
export default {
slots: {
root: ''
}
}
`
}
}
const test = ({ name, prose, content }) => {
const upperName = splitByCase(name).map(p => upperFirst(p)).join('')
return {
filename: `test/components/${content ? 'content/' : ''}${upperName}.spec.ts`,
contents: prose
? undefined
: `
import { describe, it, expect } from 'vitest'
import ${upperName}, { type ${upperName}Props, type ${upperName}Slots } from '../../${content ? '../' : ''}src/runtime/components/${content ? 'content/' : ''}${upperName}.vue'
import ComponentRender from '../${content ? '../' : ''}component-render'
describe('${upperName}', () => {
it.each([
// Props
['with as', { props: { as: 'section' } }],
['with class', { props: { class: '' } }],
['with ui', { props: { ui: {} } }],
// Slots
['with default slot', { slots: { default: () => 'Default slot' } }]
])('renders %s correctly', async (nameOrHtml: string, options: { props?: ${upperName}Props, slots?: Partial<${upperName}Slots> }) => {
const html = await ComponentRender(nameOrHtml, options, ${upperName})
expect(html).toMatchSnapshot()
})
})
`
}
}
const doc = ({ name, pro }) => {
const kebabName = kebabCase(name)
const upperName = splitByCase(name).map(p => upperFirst(p)).join('')
return {
filename: `docs/content/${pro ? 'pro' : '3.components'}/${kebabName}.md`,
contents: `---
description:
links: ${pro
? ''
: `
- label: ${upperName}
icon: i-custom-reka-ui
to: https://www.reka-ui.com/components/${kebabName}.html`}
- label: GitHub
icon: i-simple-icons-github
to: https://github.com/nuxt/${pro ? 'ui-pro' : 'ui'}/tree/v3/src/runtime/components/${upperName}.vue
---
## Usage
## Examples
## API
### Props
:component-props
### Slots
:component-slots
### Emits
:component-emits
## Theme
:component-theme
`
}
}
export default {
playground,
component,
theme,
test,
doc
}

31
cli/utils.mjs Normal file
View File

@@ -0,0 +1,31 @@
import { promises as fsp } from 'node:fs'
export async function sortFile(path) {
const file = await fsp.readFile(path, 'utf-8')
const lines = file.trim().split('\n').sort()
await fsp.writeFile(path, lines.join('\n') + '\n')
}
export async function appendFile(path, contents) {
const file = await fsp.readFile(path, 'utf-8')
if (!file.includes(contents)) {
await fsp.writeFile(path, file.trim() + '\n' + contents + '\n')
}
}
export function normalizeLocale(locale) {
if (!locale) {
return ''
}
if (locale.includes('_')) {
return locale.split('_')
.map((part, index) => index === 0 ? part.toLowerCase() : part.toUpperCase())
.join('-')
}
return locale.toLowerCase()
}

View File

@@ -0,0 +1,8 @@
export default defineAppConfig({
ui: {
colors: {
primary: 'green',
neutral: 'zinc'
}
}
})

222
devtools/app/app.vue Normal file
View File

@@ -0,0 +1,222 @@
<script setup lang="ts">
import type { Component } from '../../src/devtools/meta'
import { watchDebounced } from '@vueuse/core'
// Disable devtools in component renderer iframe
// @ts-expect-error - Nuxt Devtools internal value
window.__NUXT_DEVTOOLS_DISABLE__ = true
const component = useState<Component | undefined>('__ui-devtools-component')
const state = useState<Record<string, any>>('__ui-devtools-state', () => ({}))
const { data: components, status, error } = useAsyncData<Array<Component>>('__ui-devtools-components', async () => {
const componentMeta = await $fetch<Record<string, Component>>('/api/component-meta')
if (!component.value || !componentMeta[component.value.slug]) {
component.value = componentMeta['button']
}
state.value.props = Object.values(componentMeta).reduce((acc, comp) => {
const componentDefaultProps = comp.meta?.props.reduce((acc, prop) => {
if (prop.default) acc[prop.name] = prop.default
return acc
}, {} as Record<string, any>)
acc[comp.slug] = {
...comp.defaultVariants, // Default values from the theme template
...componentDefaultProps, // Default values from vue props
...componentMeta[comp.slug]?.meta?.devtools?.defaultProps // Default values from devtools extended meta
}
return acc
}, {} as Record<string, any>)
return Object.values(componentMeta)
})
const componentProps = computed(() => {
if (!component.value) return
return state.value.props[component.value?.slug]
})
const componentPropsMeta = computed(() => {
return component.value?.meta?.props.filter(prop => prop.name !== 'ui').sort((a, b) => a.name.localeCompare(b.name))
})
function updateRenderer() {
if (!component.value) return
const event: Event & { data?: any } = new Event('nuxt-ui-devtools:update-renderer')
event.data = {
props: state.value.props?.[component.value.slug], slots: state.value.slots?.[component.value?.slug]
}
window.dispatchEvent(event)
}
watchDebounced(state, updateRenderer, { deep: true, debounce: 200, maxWait: 500 })
onMounted(() => window.addEventListener('nuxt-ui-devtools:component-loaded', onComponentLoaded))
onUnmounted(() => window.removeEventListener('nuxt-ui-devtools:component-loaded', onComponentLoaded))
function onComponentLoaded() {
if (!component.value) return
updateRenderer()
}
const tabs = computed(() => {
if (!component.value) return
return [
{ label: 'Props', slot: 'props', icon: 'i-lucide-settings', disabled: !component.value.meta?.props?.length }
]
})
function openDocs() {
if (!component.value) return
window.parent.open(`https://ui3.nuxt.dev/components/${component.value.slug}`)
}
const colorMode = useColorMode()
const isDark = computed({
get() {
return colorMode.value === 'dark'
},
set(value) {
colorMode.preference = value ? 'dark' : 'light'
const event: Event & { isDark?: boolean } = new Event('nuxt-ui-devtools:set-color-mode')
event.isDark = value
window.dispatchEvent(event)
}
})
</script>
<template>
<UApp class="flex justify-center items-center h-screen w-full relative font-sans">
<div v-if="status === 'pending' || error || !component || !components?.length">
<div v-if="error" class="flex flex-col justify-center items-center h-screen w-screen text-center text-[var(--ui-color-error-500)]">
<UILogo class="h-8" />
<UIcon name="i-lucide-circle-alert" size="20" class="mt-2" />
<p>
{{ (error.data as any)?.error ?? 'Unexpected error' }}
</p>
</div>
</div>
<template v-else>
<div
class="top-0 h-[49px] border-b border-[var(--ui-border)] flex justify-center"
>
<span />
<UInputMenu
v-model="component"
variant="none"
:items="components"
placeholder="Search component..."
class="top-0 translate-y-0 w-full mx-2"
icon="i-lucide-search"
/>
<div class="absolute top-[49px] bottom-0 inset-x-0 grid xl:grid-cols-8 grid-cols-4 bg-[var(--ui-bg)]">
<div class="col-span-1 border-r border-[var(--ui-border)] hidden xl:block overflow-y-auto">
<UNavigationMenu
:items="components.map((c) => ({ ...c, active: c.slug === component?.slug, onSelect: () => component = c }))"
orientation="vertical"
:ui="{ link: 'before:rounded-none' }"
/>
</div>
<div class="xl:col-span-5 col-span-2 relative">
<ComponentPreview :component="component" :props="componentProps" class="h-full" />
<div class="flex gap-2 absolute top-1 right-2">
<UButton
:icon="isDark ? 'i-lucide-moon' : 'i-lucide-sun'"
variant="ghost"
color="neutral"
@click="isDark = !isDark"
/>
<UButton
v-if="component"
variant="ghost"
color="neutral"
icon="i-lucide-external-link"
@click="openDocs()"
>
Open docs
</UButton>
</div>
</div>
<div class="border-l border-[var(--ui-border)] flex flex-col col-span-2 overflow-y-auto">
<UTabs color="neutral" variant="link" :items="tabs" class="relative" :ui="{ list: 'sticky top-0 bg-[var(--ui-bg)] z-50' }">
<template #props>
<div v-for="prop in componentPropsMeta" :key="'prop-' + prop.name" class="px-3 py-5 border-b border-[var(--ui-border)]">
<ComponentPropInput
v-model="componentProps[prop.name]"
:meta="prop"
:ignore="component.meta?.devtools?.ignoreProps?.includes(prop.name)"
/>
</div>
</template>
</UTabs>
</div>
</div>
</div>
</template>
</UApp>
</template>
<style>
@import 'tailwindcss';
@import '@nuxt/ui';
@theme {
--font-sans: 'DM Sans', sans-serif;
--color-primary-50: var(--ui-color-primary-50);
--color-primary-100: var(--ui-color-primary-100);
--color-primary-200: var(--ui-color-primary-200);
--color-primary-300: var(--ui-color-primary-300);
--color-primary-400: var(--ui-color-primary-400);
--color-primary-500: var(--ui-color-primary-500);
--color-primary-600: var(--ui-color-primary-600);
--color-primary-700: var(--ui-color-primary-700);
--color-primary-800: var(--ui-color-primary-800);
--color-primary-900: var(--ui-color-primary-900);
--color-primary-950: var(--ui-color-primary-950);
--color-neutral-50: var(--ui-color-neutral-50);
--color-neutral-100: var(--ui-color-neutral-100);
--color-neutral-200: var(--ui-color-neutral-200);
--color-neutral-300: var(--ui-color-neutral-300);
--color-neutral-400: var(--ui-color-neutral-400);
--color-neutral-500: var(--ui-color-neutral-500);
--color-neutral-600: var(--ui-color-neutral-600);
--color-neutral-700: var(--ui-color-neutral-700);
--color-neutral-800: var(--ui-color-neutral-800);
--color-neutral-900: var(--ui-color-neutral-900);
--color-neutral-950: var(--ui-color-neutral-950);
}
:root {
--ui-border: var(--ui-color-neutral-200);
--ui-bg: white;
}
.dark {
--ui-border: var(--ui-color-neutral-800);
--ui-bg: var(--ui-color-neutral-900);
}
.shiki
.shiki span {
background-color: transparent !important;
}
html.dark .shiki,
html.dark .shiki span {
color: var(--shiki-dark) !important;
background-color: transparent !important;
/* Optional, if you also want font styles */
font-style: var(--shiki-dark-font-style) !important;
font-weight: var(--shiki-dark-font-weight) !important;
text-decoration: var(--shiki-dark-text-decoration) !important;
}
</style>

View File

@@ -0,0 +1,43 @@
<script setup lang="ts">
import { ref, computed, onMounted } from 'vue'
const collapsed = ref(true)
const wrapper = ref<HTMLElement | null>(null)
const content = ref<HTMLElement | null>(null)
const overflow = computed(() => {
if (!content.value || !wrapper.value) return false
return content.value.scrollHeight > 48 * 4
})
onMounted(() => {
if (wrapper.value) {
wrapper.value.style.transition = 'max-height 0.3s ease' // Set transition for max-height
}
})
</script>
<template>
<div class="border rounded-[var(--ui-radius)] border-[var(--ui-border)]">
<div
ref="wrapper"
:class="['overflow-hidden', collapsed && overflow ? 'max-h-48' : 'max-h-none']"
>
<div ref="content">
<slot />
</div>
</div>
<UButton
v-if="overflow"
class="bg-[var(--ui-bg)] group w-full flex justify-center my-1 border-t border-[var(--ui-border)] rounded-t-none"
variant="link"
color="neutral"
trailing-icon="i-lucide-chevron-down"
:data-state="collapsed ? 'closed' : 'open'"
:ui="{ trailingIcon: 'transition group-data-[state=open]:rotate-180' }"
@click="collapsed = !collapsed"
>
{{ collapsed ? 'Expand' : 'Collapse' }}
</UButton>
</div>
</template>

View File

@@ -0,0 +1,151 @@
<script setup lang="ts">
import type { Component } from '../../../src/devtools/meta'
import { useClipboard } from '@vueuse/core'
import { kebabCase } from 'scule'
import { escapeString } from 'knitwork'
const props = defineProps<{ component?: Component, props?: object, themeSlots?: Record<string, any> }>()
const { data: componentExample } = useAsyncData('__ui_devtools_component-source', async () => {
const example = props.component?.meta?.devtools?.example
if (!example) return false
return await $fetch<{ source: string }>(`/api/component-example`, { params: { component: example } })
}, { watch: [() => props.component?.slug] })
function genPropValue(value: any): string {
if (typeof value === 'string') {
return `'${escapeString(value).replace(/'/g, '&apos;').replace(/"/g, '&quot;')}'`
}
if (Array.isArray(value)) {
return `[ ${value.map(item => `${genPropValue(item)}`).join(',')} ]`
}
if (typeof value === 'object' && value !== null) {
const entries = Object.entries(value).map(([key, val]) => `${key}: ${genPropValue(val)}`)
return `{ ${entries.join(`,`)} }`
}
return value
}
const code = computed(() => {
if (!props.component) return
const propsTemplate = Object.entries(props.props ?? {})?.map(([key, value]: [string, any]) => {
const defaultValue: any = props.component?.meta?.props.find(prop => prop.name === key)?.default
if (defaultValue === value) return
if (value === true) return kebabCase(key)
if (value === false && defaultValue === true) return `:${kebabCase(key)}="false"`
if (!value) return
if (props.component?.defaultVariants?.[key] === value) return
if (typeof value === 'string') return `${kebabCase(key)}=${genPropValue(value)}`
return `:${kebabCase(key)}="${genPropValue(value)}"`
}).filter(Boolean).join('\n')
const slotsTemplate = props.themeSlots
? genPropValue(Object.keys(props.themeSlots).filter(key => key !== 'base').reduce((acc, key) => {
acc[key] = genPropValue(props.themeSlots?.[key])
return acc
}, {} as Record<string, string>))
: undefined
const extraTemplate = [
propsTemplate,
props.themeSlots?.base ? `class="${genPropValue(props.themeSlots.base)}"` : null,
slotsTemplate && slotsTemplate !== '{}' ? `:ui="${slotsTemplate}"` : null
].filter(Boolean).join(' ')
if (componentExample.value) {
const componentRegexp = new RegExp(`<${props.component.label}(\\s|\\r|>)`)
return componentExample.value?.source
.replace(/import .* from ['"]#.*['"];?\n+/, '')
.replace(componentRegexp, `<${props.component.label} ${extraTemplate}$1`)
.replace('v-bind="$attrs"', '')
}
return `<${props.component.label} ${extraTemplate} />`
})
const { $prettier } = useNuxtApp()
const { data: formattedCode } = useAsyncData('__ui-devtools-component-formatted-code', async () => {
if (!code.value) return
return await $prettier.format(code.value, {
semi: false,
singleQuote: true,
printWidth: 80
})
}, { watch: [code] })
const { codeToHtml } = useShiki()
const { data: highlightedCode } = useAsyncData('__ui-devtools-component-highlighted-code', async () => {
return formattedCode.value
? codeToHtml(formattedCode.value, 'vue')
: undefined
}, { watch: [formattedCode] })
const { copy, copied } = useClipboard()
const rendererVisible = ref(true)
const renderer = ref()
const rendererReady = ref(false)
function onRendererReady() {
rendererReady.value = true
setTimeout(() => rendererVisible.value = !!renderer.value.contentWindow.document.getElementById('ui-devtools-renderer'), 500)
}
watch(() => props.component, () => rendererReady.value = false)
const previewUrl = computed(() => {
if (!props.component) return
const baseUrl = `/__nuxt_ui__/components/${props.component.slug}`
const params = new URLSearchParams()
if (props.component?.meta?.devtools?.example !== undefined) {
params.append('example', props.component.meta.devtools.example)
}
const queryString = params.toString()
return queryString ? `${baseUrl}?${queryString}` : baseUrl
})
</script>
<template>
<div class="flex flex-col bg-grid">
<iframe
v-if="component"
v-show="rendererReady && rendererVisible"
ref="renderer"
class="grow w-full"
:src="previewUrl"
@load="onRendererReady"
/>
<div v-if="!rendererVisible" class="grow w-full flex justify-center items-center px-8">
<UAlert color="error" variant="subtle" title="Component preview not found" icon="i-lucide-circle-alert">
<template #description>
<p>Ensure your <code>app.vue</code> file includes a <code>&lt;NuxtPage /&gt;</code> component, as the component preview is mounted as a page. </p>
</template>
</UAlert>
</div>
<div v-if="highlightedCode && formattedCode" v-show="rendererReady" class="relative w-full p-3">
<!-- eslint-disable vue/no-v-html -->
<pre class="p-4 min-h-40 max-h-72 text-sm overflow-y-auto rounded-[calc(var(--ui-radius)*1.5)] border border-[var(--ui-border)] bg-neutral-50 dark:bg-neutral-800" v-html="highlightedCode" />
<UButton
color="neutral"
variant="link"
:icon="copied ? 'i-lucide-clipboard-check' : 'i-lucide-clipboard'"
class="absolute top-6 right-6"
@click="copy(formattedCode)"
/>
</div>
</div>
</template>
<style scoped>
.bg-grid {
background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' transform='scale(3)'%3E%3Crect width='100%25' height='100%25' fill='%23fff'/%3E%3Cpath fill='none' stroke='hsla(0, 0%25, 98%25, 1)' stroke-width='.2' d='M10 0v20ZM0 10h20Z'/%3E%3C/svg%3E");
background-size: 40px 40px;
}
.dark .bg-grid {
background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' transform='scale(3)'%3E%3Crect width='100%25' height='100%25' fill='hsl(0, 0%25, 8.5%25)'/%3E%3Cpath fill='none' stroke='hsl(0, 0%25, 11.0%25)' stroke-width='.2' d='M10 0v20ZM0 10h20Z'/%3E%3C/svg%3E");
background-size: 40px 40px;
}
</style>

View File

@@ -0,0 +1,39 @@
<script setup lang="ts">
import type { PropertyMeta } from 'vue-component-meta'
const props = defineProps<{ meta: Partial<PropertyMeta>, ignore?: boolean }>()
const modelValue = defineModel<any>()
const matchedInput = shallowRef()
const parsedSchema = shallowRef()
const { resolveInputSchema } = usePropSchema()
watchEffect(() => {
if (!props.meta?.schema) return
const result = resolveInputSchema(props.meta.schema)
parsedSchema.value = result?.schema
matchedInput.value = result?.input
})
const description = computed(() => {
return props.meta.description?.replace(/`([^`]+)`/g, '<code class="font-medium bg-[var(--ui-bg-elevated)] px-1 py-0.5 rounded-[var(--ui-radius)]">$1</code>')
})
</script>
<template>
<UFormField :name="meta?.name" class="" :ui="{ wrapper: 'mb-2' }" :class="{ 'opacity-70 cursor-not-allowed': !matchedInput || ignore }">
<template #label>
<p v-if="meta?.name" class="font-mono font-bold px-1.5 py-0.5 border border-[var(--ui-border-accented)] border-dashed rounded-[var(--ui-radius)] bg-[var(--ui-bg-elevated)]">
{{ meta?.name }}
</p>
</template>
<template #description>
<!-- eslint-disable vue/no-v-html -->
<p v-if="meta.description" class="text-neutral-600 dark:text-neutral-400 mt-1" v-html="description" />
</template>
<component :is="matchedInput.component" v-if="!ignore && matchedInput" v-model="modelValue" :schema="parsedSchema" />
</UFormField>
</template>

View File

@@ -0,0 +1,10 @@
<template>
<svg
width="1020"
height="200"
viewBox="0 0 1020 200"
fill="none"
xmlns="http://www.w3.org/2000/svg"
class="w-auto h-6 shrink-0 text-[var(--ui-text)]"
><path d="M377 200C379.16 200 381 198.209 381 196V103C381 103 386 112 395 127L434 194C435.785 197.74 439.744 200 443 200H470V50H443C441.202 50 439 51.4941 439 54V148L421 116L385 55C383.248 51.8912 379.479 50 376 50H350V200H377Z" fill="currentColor" /><path d="M726 92H739C742.314 92 745 89.3137 745 86V60H773V92H800V116H773V159C773 169.5 778.057 174 787 174H800V200H783C759.948 200 745 185.071 745 160V116H726V92Z" fill="currentColor" /><path d="M591 92V154C591 168.004 585.742 179.809 578 188C570.258 196.191 559.566 200 545 200C530.434 200 518.742 196.191 511 188C503.389 179.809 498 168.004 498 154V92H514C517.412 92 520.769 92.622 523 95C525.231 97.2459 526 98.5652 526 102V154C526 162.059 526.457 167.037 530 171C533.543 174.831 537.914 176 545 176C552.217 176 555.457 174.831 559 171C562.543 167.037 563 162.059 563 154V102C563 98.5652 563.769 96.378 566 94C567.96 91.9107 570.028 91.9599 573 92C573.411 92.0055 574.586 92 575 92H591Z" fill="currentColor" /><path d="M676 144L710 92H684C680.723 92 677.812 93.1758 676 96L660 120L645 97C643.188 94.1758 639.277 92 636 92H611L645 143L608 200H634C637.25 200 640.182 196.787 642 194L660 167L679 195C680.818 197.787 683.75 200 687 200H713L676 144Z" fill="currentColor" /><path d="M168 200H279C282.542 200 285.932 198.756 289 197C292.068 195.244 295.23 193.041 297 190C298.77 186.959 300.002 183.51 300 179.999C299.998 176.488 298.773 173.04 297 170.001L222 41C220.23 37.96 218.067 35.7552 215 34C211.933 32.2448 207.542 31 204 31C200.458 31 197.067 32.2448 194 34C190.933 35.7552 188.77 37.96 187 41L168 74L130 9.99764C128.228 6.95784 126.068 3.75491 123 2C119.932 0.245087 116.542 0 113 0C109.458 0 106.068 0.245087 103 2C99.9323 3.75491 96.7717 6.95784 95 9.99764L2 170.001C0.226979 173.04 0.00154312 176.488 1.90993e-06 179.999C-0.0015393 183.51 0.229648 186.959 2 190C3.77035 193.04 6.93245 195.244 10 197C13.0675 198.756 16.4578 200 20 200H90C117.737 200 137.925 187.558 152 164L186 105L204 74L259 168H186L168 200ZM89 168H40L113 42L150 105L125.491 147.725C116.144 163.01 105.488 168 89 168Z" fill="var(--ui-color-primary-500)" /><path d="M958 60.0001H938C933.524 60.0001 929.926 59.9395 927 63C924.074 65.8905 925 67.5792 925 72V141C925 151.372 923.648 156.899 919 162C914.352 166.931 908.468 169 899 169C889.705 169 882.648 166.931 878 162C873.352 156.899 873 151.372 873 141V72.0001C873 67.5793 872.926 65.8906 870 63.0001C867.074 59.9396 863.476 60.0001 859 60.0001H840V141C840 159.023 845.016 173.458 855 184C865.156 194.542 879.893 200 899 200C918.107 200 932.844 194.542 943 184C953.156 173.458 958 159.023 958 141V60.0001Z" fill="var(--ui-color-primary-500)" /><path fill-rule="evenodd" clip-rule="evenodd" d="M1000 60.0233L1020 60V77L1020 128V156.007L1020 181L1020 189.004C1020 192.938 1019.98 194.429 1017 197.001C1014.02 199.725 1009.56 200 1005 200H986.001V181.006L986 130.012V70.0215C986 66.1576 986.016 64.5494 989 62.023C991.819 59.6358 995.437 60.0233 1000 60.0233Z" fill="var(--ui-color-primary-500)" /></svg>
</template>

View File

@@ -0,0 +1,76 @@
<script lang="ts">
import { z } from 'zod'
export const arrayInputSchema = z.object({
kind: z.literal('array'),
schema: z.array(z.any({}))
.or(z.record(z.number(), z.any({})).transform(t => Object.values(t)))
.transform((t) => {
return t.filter(s => s !== 'undefined')
}).pipe(z.array(z.any()).max(1))
})
export type ArrayInputSchema = z.infer<typeof arrayInputSchema>
</script>
<script setup lang="ts">
const props = defineProps<{
schema: ArrayInputSchema
}>()
const modelValue = defineModel<Array<any>>({})
const itemSchema = computed(() => {
return props.schema?.schema[0]
})
function removeArrayItem(index: number) {
if (!modelValue.value) return
modelValue.value.splice(index, 1)
}
function addArrayItem() {
if (!modelValue.value) {
modelValue.value = [{}]
} else {
modelValue.value.push({})
}
}
</script>
<template>
<div>
<div v-for="value, index in modelValue" :key="index" class="relative">
<ComponentPropInput
:model-value="value"
:meta="{ schema: itemSchema }"
/>
<UPopover>
<UButton variant="ghost" color="neutral" icon="i-lucide-ellipsis-vertical" class="absolute top-4 right-1" />
<template #content>
<UButton
variant="ghost"
color="error"
icon="i-lucide-trash"
block
@click="removeArrayItem(index)"
>
Remove
</UButton>
</template>
</UPopover>
</div>
<UButton
icon="i-lucide-plus"
color="neutral"
variant="ghost"
block
class="justify-center mt-4"
@click="addArrayItem()"
>
Add value
</UButton>
</div>
</template>

View File

@@ -0,0 +1,20 @@
<script lang="ts">
import { z } from 'zod'
export const booleanInputSchema = z.literal('boolean').or(z.object({
kind: z.literal('enum'),
type: z.string().refine((type) => {
return type.split('|').some(t => t.trim() === 'boolean')
})
}))
export type BooleanInputSchema = z.infer<typeof booleanInputSchema>
</script>
<script setup lang="ts">
defineProps<{ schema: BooleanInputSchema }>()
</script>
<template>
<USwitch />
</template>

View File

@@ -0,0 +1,15 @@
<script lang="ts">
import { z } from 'zod'
export const numberInputSchema = z.literal('number')
export type NumberInputSchema = z.infer<typeof numberInputSchema>
</script>
<script setup lang="ts">
defineProps<{ schema: NumberInputSchema }>()
const modelValue = defineModel<number>()
</script>
<template>
<UInput v-model.number="modelValue" type="number" />
</template>

View File

@@ -0,0 +1,38 @@
<script lang="ts">
import { z } from 'zod'
export const objectInputSchema = z.object({
kind: z.literal('object'),
schema: z.record(z.string(), z.any())
})
export type ObjectInputSchema = z.infer<typeof objectInputSchema>
</script>
<script setup lang="ts">
const props = defineProps<{
schema: ObjectInputSchema
}>()
const modelValue = defineModel<Record<string, any>>({})
const attributesSchemas = computed(() => {
return Object.values(props.schema.schema)
})
</script>
<template>
<CollapseContainer>
<ComponentPropInput
v-for="attributeSchema in attributesSchemas"
:key="attributeSchema.name"
class="border-b last:border-b-0 border-[var(--ui-border)] p-4"
:model-value="modelValue?.[attributeSchema.name]"
:meta="attributeSchema"
@update:model-value="(value: any) => {
if (!modelValue) modelValue ||= {}
else modelValue[attributeSchema.name] = value
}"
/>
</CollapseContainer>
</template>

View File

@@ -0,0 +1,60 @@
<script lang="ts">
import { z } from 'zod'
export const stringEnumInputSchema = z.object({
kind: z.literal('enum'),
schema: z.array(z.string())
.or(z.record(z.any(), z.string()).transform<string[]>(t => Object.values(t)))
.transform<string[]>(t => t.filter(s => s.trim().match(/^["'`]/)).map(s => s.trim().replaceAll(/["'`]/g, '')))
.pipe(z.array(z.string()).min(1))
})
export type StringEnumInputSchema = z.infer<typeof stringEnumInputSchema>
</script>
<script setup lang="ts">
const props = defineProps<{
schema: StringEnumInputSchema
}>()
const sizes = ['xs', 'sm', 'md', 'lg', 'xl']
function parseSize(size: string) {
const sizePattern = sizes.join('|')
const regex = new RegExp(`^(\\d*)(${sizePattern})$`, 'i')
const match = size.match(regex)
if (!match) return null
const number = match[1] ? Number.parseInt(match[1], 10) : 1 // Default to 1 if no number is present
const suffix = match[2] ?? ''
return { number, suffix }
}
const options = computed(() => {
return [...props.schema.schema].sort((a, b) => {
const sizeA = parseSize(a)
const sizeB = parseSize(b)
if (!sizeA || !sizeB) return a.localeCompare(b)
const suffixAIndex = sizes.indexOf(sizeA.suffix)
const suffixBIndex = sizes.indexOf(sizeB.suffix)
if (suffixAIndex !== -1 && suffixBIndex !== -1) {
if (suffixAIndex !== suffixBIndex) {
return suffixAIndex - suffixBIndex
}
} else if (suffixAIndex === -1 || suffixBIndex === -1) {
if (sizeA.suffix !== sizeB.suffix) {
return sizeA.suffix.localeCompare(sizeB.suffix)
}
}
return sizeA.number - sizeB.number
})
})
</script>
<template>
<USelectMenu :items="options" class="min-w-[167px]" />
</template>

View File

@@ -0,0 +1,15 @@
<script lang="ts">
import { z } from 'zod'
export const stringInputSchema = z.literal('string').or(z.string().transform(t => t.split('|').find(s => s.trim() === 'string')).pipe(z.string()))
export type StringInputSchema = z.infer<typeof stringInputSchema>
</script>
<script setup lang="ts">
defineProps<{ schema: StringInputSchema }>()
</script>
<template>
<UInput />
</template>

View File

@@ -0,0 +1,44 @@
import type { PropertyMeta } from 'vue-component-meta'
import BooleanInput, { booleanInputSchema } from '../components/inputs/BooleanInput.vue'
import StringInput, { stringInputSchema } from '../components/inputs/StringInput.vue'
import NumberInput, { numberInputSchema } from '../components/inputs/NumberInput.vue'
import StringEnumInput, { stringEnumInputSchema } from '../components/inputs/StringEnumInput.vue'
import ObjectInput, { objectInputSchema } from '../components/inputs/ObjectInput.vue'
import ArrayInput, { arrayInputSchema } from '../components/inputs/ArrayInput.vue'
// List of available inputs.
const availableInputs = [
{ id: 'string', schema: stringInputSchema, component: StringInput },
{ id: 'number', schema: numberInputSchema, component: NumberInput },
{ id: 'boolean', schema: booleanInputSchema, component: BooleanInput },
{ id: 'stringEnum', schema: stringEnumInputSchema, component: StringEnumInput },
{ id: 'object', schema: objectInputSchema, component: ObjectInput },
{ id: 'array', schema: arrayInputSchema, component: ArrayInput }
]
export function usePropSchema() {
function resolveInputSchema(schema: PropertyMeta['schema']): { schema: PropertyMeta['schema'], input: any } | undefined {
// Return the first input in the list of available inputs that matches the schema.
for (const input of availableInputs) {
const result = input.schema.safeParse(schema)
if (result.success) {
// Returns the output from zod to get the transformed output.
// It only includes attributes defined in the zod schema.
return { schema: result.data as PropertyMeta['schema'], input }
}
}
if (typeof schema === 'string') return
// If the schema is a complex enum or array return the first nested schema that matches an input.
if (schema.kind === 'enum' && schema.schema) {
const enumSchemas = typeof schema.schema === 'object' ? Object.values(schema.schema) : schema.schema
for (const enumSchema of enumSchemas) {
const result = resolveInputSchema(enumSchema)
if (result) return result
}
}
}
return { resolveInputSchema }
}

View File

@@ -0,0 +1,34 @@
import { createHighlighterCore } from 'shiki/core'
import type { BuiltinLanguage, HighlighterCore } from 'shiki'
import loadWasm from 'shiki/wasm'
import MaterialThemeLighter from 'shiki/themes/material-theme-lighter.mjs'
import MaterialThemePalenight from 'shiki/themes/material-theme-palenight.mjs'
import VueLang from 'shiki/langs/vue.mjs'
import MarkdownLang from 'shiki/langs/markdown.mjs'
export const highlighter = shallowRef<HighlighterCore>()
// A custom composable for syntax highlighting with Shiki since `@nuxt/mdc` relies on
// a server endpoint to highlight code.
export function useShiki() {
async function codeToHtml(code: string, lang: BuiltinLanguage | 'text' = 'text') {
if (!highlighter.value) {
highlighter.value = await createHighlighterCore({
themes: [MaterialThemeLighter, MaterialThemePalenight],
langs: [VueLang, MarkdownLang],
loadWasm
})
}
return highlighter.value.codeToHtml(code, {
lang,
themes: {
dark: 'material-theme-palenight',
default: 'material-theme-lighter',
light: 'material-theme-lighter'
}
})
}
return { codeToHtml }
}

View File

@@ -0,0 +1,54 @@
import type { Options } from 'prettier'
import PrettierWorker from '@/workers/prettier.js?worker&inline'
export interface SimplePrettier {
format: (source: string, options?: Options) => Promise<string>
}
function createPrettierWorkerApi(worker: Worker): SimplePrettier {
let counter = 0
const handlers: any = {}
worker.addEventListener('message', (event) => {
const { uid, message, error } = event.data
if (!handlers[uid]) {
return
}
const [resolve, reject] = handlers[uid]
// eslint-disable-next-line @typescript-eslint/no-dynamic-delete
delete handlers[uid]
if (error) {
reject(error)
} else {
resolve(message)
}
})
function postMessage<T>(message: any) {
const uid = ++counter
return new Promise<T>((resolve, reject) => {
handlers[uid] = [resolve, reject]
worker.postMessage({ uid, message })
})
}
return {
format(source: string, options?: Options) {
return postMessage({ type: 'format', source, options })
}
}
}
export default defineNuxtPlugin(async () => {
const worker = new PrettierWorker()
const prettier = createPrettierWorkerApi(worker)
return {
provide: {
prettier
}
}
})

View File

@@ -0,0 +1,36 @@
/* eslint-disable no-undef */
self.onmessage = async function (event) {
self.postMessage({
uid: event.data.uid,
message: await handleMessage(event.data.message)
})
}
function handleMessage(message) {
switch (message.type) {
case 'format':
return handleFormatMessage(message)
}
}
async function handleFormatMessage(message) {
if (!globalThis.prettier) {
await Promise.all([
import('https://unpkg.com/prettier@3.3.3/standalone.js'),
import('https://unpkg.com/prettier@3.3.3/plugins/html.js'),
import('https://unpkg.com/prettier@3.3.3/plugins/postcss.js'),
import('https://unpkg.com/prettier@3.3.3/plugins/babel.js'),
import('https://unpkg.com/prettier@3.3.3/plugins/estree.js'),
import('https://unpkg.com/prettier@3.3.3/plugins/typescript.js')
])
}
const { options, source } = message
const formatted = await prettier.format(source, {
parser: 'vue',
plugins: prettierPlugins,
...options
})
return formatted
}

38
devtools/nuxt.config.ts Normal file
View File

@@ -0,0 +1,38 @@
import { resolve } from 'node:path'
export default defineNuxtConfig({
modules: ['../src/module', '@nuxt/test-utils/module'],
ssr: false,
devtools: { enabled: false },
app: {
baseURL: '/__nuxt_ui__/devtools'
},
future: {
compatibilityVersion: 4
},
compatibilityDate: '2024-04-03',
nitro: {
hooks: {
'prerender:routes': function (routes) {
routes.clear()
}
},
output: {
publicDir: resolve(__dirname, '../dist/client/devtools')
}
},
vite: {
server: {
hmr: {
clientPort: process.env.PORT ? +process.env.PORT : undefined
}
}
}
})

19
devtools/package.json Normal file
View File

@@ -0,0 +1,19 @@
{
"name": "@nuxt/ui-devtools",
"private": true,
"type": "module",
"scripts": {
"build": "nuxt build",
"dev": "nuxt dev",
"generate": "nuxt generate",
"preview": "nuxt preview",
"test": "vitest"
},
"dependencies": {
"@nuxt/ui": "latest",
"knitwork": "^1.1.0",
"nuxt": "^3.14.1592",
"prettier": "^3.4.2",
"zod": "^3.23.8"
}
}

View File

@@ -0,0 +1 @@
<svg fill="none" xmlns="http://www.w3.org/2000/svg" class="w-auto h-6 shrink-0" viewBox="840 60 180 140"><path d="M958 60.0001H938C933.524 60.0001 929.926 59.9395 927 63C924.074 65.8905 925 67.5792 925 72V141C925 151.372 923.648 156.899 919 162C914.352 166.931 908.468 169 899 169C889.705 169 882.648 166.931 878 162C873.352 156.899 873 151.372 873 141V72.0001C873 67.5793 872.926 65.8906 870 63.0001C867.074 59.9396 863.476 60.0001 859 60.0001H840V141C840 159.023 845.016 173.458 855 184C865.156 194.542 879.893 200 899 200C918.107 200 932.844 194.542 943 184C953.156 173.458 958 159.023 958 141V60.0001Z" fill="currentColor"></path><path fill-rule="evenodd" clip-rule="evenodd" d="M1000 60.0233L1020 60V77L1020 128V156.007L1020 181L1020 189.004C1020 192.938 1019.98 194.429 1017 197.001C1014.02 199.725 1009.56 200 1005 200H986.001V181.006L986 130.012V70.0215C986 66.1576 986.016 64.5494 989 62.023C991.819 59.6358 995.437 60.0233 1000 60.0233Z" fill="currentColor"></path> <style> path { fill: #00000080; } @media (prefers-color-scheme: dark) { path { fill: #ffffff80; } } </style> </svg>

After

Width:  |  Height:  |  Size: 1.1 KiB

View File

@@ -0,0 +1,24 @@
// @vitest-environment node
import { it, expect, describe } from 'vitest'
import { usePropSchema } from '../../app/composables/usePropSchema'
import { stringSchema, optionalStringSchema, booleanSchema, numberSchema, optionalNumberSchema, optionalBooleanSchema, objectSchema, arraySchema, arrayOptionalSchema, stringEnumSchema } from '../fixtures/schemas'
describe('usePropSchema', () => {
const { resolveInputSchema } = usePropSchema()
it.each([
['string', { schema: stringSchema, inputId: 'string' }],
['optional string', { schema: optionalStringSchema, inputId: 'string' }],
['number', { schema: numberSchema, inputId: 'number' }],
['optional number', { schema: optionalNumberSchema, inputId: 'number' }],
['boolean', { schema: booleanSchema, inputId: 'boolean' }],
['string enum', { schema: stringEnumSchema, inputId: 'stringEnum' }],
['object', { schema: objectSchema, inputId: 'object' }],
['optional boolean', { schema: optionalBooleanSchema, inputId: 'boolean' }],
['array', { schema: arraySchema, inputId: 'array' }],
['optional array', { schema: arrayOptionalSchema, inputId: 'array' }]
])('resolveInputSchema should resolve %s schema', async (_: string, options) => {
const result = resolveInputSchema(options.schema as any)
expect(result?.input.id).toBe(options.inputId)
})
})

133
devtools/test/fixtures/schemas.ts vendored Normal file
View File

@@ -0,0 +1,133 @@
export const stringSchema = 'string' as const
export const optionalStringSchema = {
kind: 'enum',
type: 'string | undefined',
schema: {
0: 'undefined',
1: 'string'
}
}
export const numberSchema = 'number' as const
export const optionalNumberSchema = {
kind: 'enum',
type: 'number | undefined',
schema: {
0: 'undefined',
1: 'number'
}
}
export const booleanSchema = 'boolean' as const
export const optionalBooleanSchema = {
kind: 'enum',
type: 'boolean | undefined',
schema: {
0: 'undefined',
1: 'boolean'
}
}
export const objectSchema = {
kind: 'object',
type: 'AccordionItem',
schema: {
label: {
name: 'label',
global: false,
description: '',
tags: [],
required: false,
type: 'string | undefined',
schema: {
kind: 'enum',
type: 'string | undefined',
schema: {
0: 'undefined',
1: 'string'
}
}
}
}
}
export const arraySchema = {
kind: 'array',
type: 'AccordionItem[]',
schema: [
{
kind: 'object',
type: 'AccordionItem',
schema: {
label: {
name: 'label',
global: false,
description: '',
tags: [],
required: false,
type: 'string | undefined',
schema: {
kind: 'enum',
type: 'string | undefined',
schema: {
0: 'undefined',
1: 'string'
}
}
}
}
}
]
}
export const arrayOptionalSchema = {
kind: 'enum',
type: 'AccordionItem[] | undefined',
schema: {
0: 'undefined',
1: {
kind: 'array',
type: 'AccordionItem[]',
schema: [
{
kind: 'object',
type: 'AccordionItem',
schema: {
label: {
name: 'label',
global: false,
description: '',
tags: [],
required: false,
type: 'string | undefined',
schema: {
kind: 'enum',
type: 'string | undefined',
schema: {
0: 'undefined',
1: 'string'
}
}
}
}
}
]
}
}
}
export const stringEnumSchema = {
kind: 'enum',
type: '"true" | "false" | "page" | "step" | "location" | "date" | "time" | undefined',
schema: {
0: 'undefined',
1: '"true"',
2: '"false"',
3: '"page"',
4: '"step"',
5: '"location"',
6: '"date"',
7: '"time"'
}
}

View File

@@ -0,0 +1,7 @@
import { defineVitestConfig } from '@nuxt/test-utils/config'
export default defineVitestConfig({
test: {
environment: 'nuxt'
}
})

4
devtools/tsconfig.json Normal file
View File

@@ -0,0 +1,4 @@
{
// https://nuxt.com/docs/guide/concepts/typescript
"extends": "./.nuxt/tsconfig.json"
}

View File

@@ -1,6 +0,0 @@
export default defineAppConfig({
ui: {
primary: 'green',
gray: 'slate'
}
})

View File

@@ -1,123 +0,0 @@
<!-- eslint-disable vue/no-v-html -->
<template>
<div>
<NuxtLoadingIndicator />
<Banner v-if="!$route.path.startsWith('/examples')" />
<Header v-if="!$route.path.startsWith('/examples')" :links="links" />
<NuxtLayout>
<NuxtPage />
</NuxtLayout>
<Footer v-if="!$route.path.startsWith('/examples')" />
<ClientOnly>
<LazyUContentSearch ref="searchRef" :files="files" :navigation="navigation" :links="links" :fuse="{ resultLimit: 42 }" />
</ClientOnly>
<UNotifications>
<template #title="{ title }">
<span v-html="title" />
</template>
</UNotifications>
<UModals />
<USlideovers />
</div>
</template>
<script setup lang="ts">
import { withoutTrailingSlash } from 'ufo'
import { debounce } from 'perfect-debounce'
import type { ParsedContent } from '@nuxt/content'
const searchRef = ref()
const route = useRoute()
const colorMode = useColorMode()
const { branch } = useContentSource()
const { data: nav } = await useAsyncData('navigation', () => fetchContentNavigation())
const { data: files } = useLazyFetch<ParsedContent[]>('/api/search.json', { default: () => [], server: false })
// Computed
const navigation = computed(() => {
if (branch.value?.name === 'dev') {
const dev = nav.value.find(item => item._path === '/dev')?.children
const pro = nav.value.find(item => item._path === '/pro')
return [
...dev,
...(pro ? [pro] : [])
]
}
return nav.value?.filter(item => item._path !== '/dev') || []
})
const color = computed(() => colorMode.value === 'dark' ? '#18181b' : 'white')
const links = computed(() => {
return [{
label: 'Docs',
icon: 'i-heroicons-book-open',
to: branch.value?.name === 'dev' ? '/dev/getting-started' : '/getting-started',
active: branch.value?.name === 'dev' ? (route.path.startsWith('/dev/getting-started') || route.path.startsWith('/dev/components')) : (route.path.startsWith('/getting-started') || route.path.startsWith('/components'))
}, ...(navigation.value.find(item => item._path === '/pro') ? [{
label: 'Pro',
icon: 'i-heroicons-square-3-stack-3d',
to: '/pro',
active: route.path.startsWith('/pro/getting-started') || route.path.startsWith('/pro/components') || route.path.startsWith('/pro/prose')
}, {
label: 'Pricing',
icon: 'i-heroicons-ticket',
to: '/pro/pricing'
}, {
label: 'Templates',
icon: 'i-heroicons-computer-desktop',
to: '/pro/templates'
}] : []), {
label: 'Releases',
icon: 'i-heroicons-rocket-launch',
to: '/releases'
}].filter(Boolean)
})
// Watch
watch(() => searchRef.value?.commandPaletteRef?.query, debounce((query: string) => {
if (!query) {
return
}
useTrackEvent('Search', { props: { query: `${query} - ${searchRef.value?.commandPaletteRef.results.length} results` } })
}, 500))
// Head
useHead({
meta: [
{ name: 'viewport', content: 'width=device-width, initial-scale=1' },
{ key: 'theme-color', name: 'theme-color', content: color }
],
link: [
{ rel: 'icon', type: 'image/svg+xml', href: '/icon.svg' },
{ rel: 'canonical', href: `https://ui.nuxt.com${withoutTrailingSlash(route.path)}` }
],
htmlAttrs: {
lang: 'en'
}
})
useServerSeoMeta({
ogSiteName: 'Nuxt UI',
twitterCard: 'summary_large_image'
})
// Provide
provide('navigation', navigation)
provide('files', files)
</script>

16
docs/app/app.config.ts Normal file
View File

@@ -0,0 +1,16 @@
export default defineAppConfig({
toaster: {
position: 'bottom-right' as const,
expand: true,
duration: 5000
},
theme: {
radius: 0.25
},
ui: {
colors: {
primary: 'green',
neutral: 'slate'
}
}
})

154
docs/app/app.vue Normal file
View File

@@ -0,0 +1,154 @@
<script setup lang="ts">
import { withoutTrailingSlash } from 'ufo'
import colors from 'tailwindcss/colors'
// import { debounce } from 'perfect-debounce'
const route = useRoute()
const appConfig = useAppConfig()
const colorMode = useColorMode()
const { data: navigation } = await useAsyncData('navigation', () => queryCollectionNavigation('content', ['framework', 'module']))
const { data: files } = useLazyAsyncData('search', () => queryCollectionSearchSections('content'), {
server: false
})
const searchTerm = ref('')
// watch(searchTerm, debounce((query: string) => {
// if (!query) {
// return
// }
// useTrackEvent('Search', { props: { query: `${query} - ${searchTerm.value?.commandPaletteRef.results.length} results` } })
// }, 500))
const links = computed(() => [{
label: 'Docs',
icon: 'i-lucide-square-play',
to: '/getting-started',
active: route.path.startsWith('/getting-started')
}, {
label: 'Components',
icon: 'i-lucide-square-code',
to: '/components',
active: route.path.startsWith('/components')
}, {
label: 'Roadmap',
icon: 'i-lucide-map',
to: '/roadmap'
}, {
label: 'Figma',
icon: 'i-lucide-figma',
to: 'https://www.figma.com/community/file/1288455405058138934',
target: '_blank'
}, {
label: 'Releases',
icon: 'i-lucide-rocket',
to: 'https://github.com/nuxt/ui/releases',
target: '_blank'
}].filter(Boolean))
const color = computed(() => colorMode.value === 'dark' ? (colors as any)[appConfig.ui.colors.neutral][900] : 'white')
const radius = computed(() => `:root { --ui-radius: ${appConfig.theme.radius}rem; }`)
useHead({
meta: [
{ name: 'viewport', content: 'width=device-width, initial-scale=1' },
{ key: 'theme-color', name: 'theme-color', content: color }
],
link: [
{ rel: 'icon', type: 'image/svg+xml', href: '/icon.svg' },
{ rel: 'canonical', href: `https://ui.nuxt.com${withoutTrailingSlash(route.path)}` }
],
style: [
{ innerHTML: radius, id: 'nuxt-ui-radius', tagPriority: -2 }
],
htmlAttrs: {
lang: 'en'
}
})
useServerSeoMeta({
ogSiteName: 'Nuxt UI',
twitterCard: 'summary_large_image'
})
const { frameworks, modules } = useSharedData()
const { mappedNavigation, filteredNavigation } = useContentNavigation(navigation)
provide('navigation', mappedNavigation)
</script>
<template>
<UApp :toaster="appConfig.toaster">
<NuxtLoadingIndicator color="#FFF" />
<template v-if="!route.path.startsWith('/examples')">
<!-- <Banner /> -->
<Header :links="links" />
</template>
<NuxtLayout>
<NuxtPage />
</NuxtLayout>
<template v-if="!route.path.startsWith('/examples')">
<!-- <Footer /> -->
<ClientOnly>
<LazyUContentSearch
v-model:search-term="searchTerm"
:files="files"
:groups="[{
id: 'framework',
label: 'Framework',
items: frameworks
}, {
id: 'module',
label: 'Module',
items: modules
}]"
:navigation="filteredNavigation"
:fuse="{ resultLimit: 42 }"
/>
</ClientOnly>
</template>
</UApp>
</template>
<style>
@import "tailwindcss";
@import "@nuxt/ui-pro";
@source "../content";
@theme {
--container-8xl: 90rem;
--font-sans: 'Public Sans', sans-serif;
--color-green-50: #EFFDF5;
--color-green-100: #D9FBE8;
--color-green-200: #B3F5D1;
--color-green-300: #75EDAE;
--color-green-400: #00DC82;
--color-green-500: #00C16A;
--color-green-600: #00A155;
--color-green-700: #007F45;
--color-green-800: #016538;
--color-green-900: #0A5331;
--color-green-950: #052E16;
}
:root {
--ui-container: var(--container-8xl);
}
html[data-framework="nuxt"] .vue-only,
html[data-framework="vue"] .nuxt-only,
html[data-module="ui-pro"] .ui-only,
html[data-module="ui"] .ui-pro-only {
display: none;
}
</style>

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 13 KiB

View File

@@ -0,0 +1,10 @@
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 283.46 283.46">
<defs>
<style>
.cls-1{fill:#231815;}
@media (prefers-color-scheme: dark) { .cls-1{fill:#ffffff;} }
</style>
</defs>
<path class="cls-1" d="M144.89,89.86c-33.46,0-54.44,14.56-66.14,26.76a86,86,0,0,0-23.69,58.94c0,22.64,8.81,43.48,24.8,58.67,15.7,14.92,36.9,23.14,59.68,23.14,23.81,0,46-8.49,62.49-23.91,17-15.9,26.37-37.93,26.37-62C228.4,120.37,185.94,89.86,144.89,89.86Zm.49,153.67a61.49,61.49,0,0,1-46.45-20.4c-12.33-13.76-18.85-32.64-18.85-54.62,0-20.7,6.07-37.67,17.57-49.07,10.11-10,24.39-15.62,40.19-15.74,19,0,35.22,6.56,46.76,19,12.6,13.58,19.27,34,19.27,58.95C203.87,224.39,174.49,243.53,145.38,243.53Z"/>
<polygon class="cls-1" points="198.75 74.96 179.45 74.96 142.09 37.83 104.51 74.96 86.14 74.96 138.09 24.25 146.81 24.25 198.75 74.96"/>
</svg>

After

Width:  |  Height:  |  Size: 855 B

View File

@@ -0,0 +1,34 @@
<svg width="290" height="290" viewBox="0 0 290 290" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M226.269 52.4044L226.274 52.4067C237.406 58.2619 245.614 66.3008 250.94 76.5218C256.285 86.7776 258.969 98.4614 258.969 111.596C258.969 124.732 256.285 136.34 250.943 146.446C245.618 156.521 237.447 164.451 226.389 170.234C221.59 172.712 219.355 178.881 222.459 183.542L257.922 236.789C261.773 242.571 257.628 250.311 250.681 250.311H196.906C193.806 250.311 190.939 248.661 189.382 245.98L79.3991 56.5686C76.0313 50.7687 80.2159 43.5 86.9227 43.5H183.394C200.888 43.5 215.161 46.4896 226.269 52.4044Z" fill="url(#paint0_linear_30_25)" stroke="url(#paint1_linear_30_25)" stroke-width="1.93333"/>
<path d="M116.722 247.228C113.004 253.687 103.684 253.687 99.9661 247.228L26.2042 119.085C22.4947 112.64 27.1462 104.596 34.5821 104.596L182.106 104.596C189.542 104.596 194.193 112.64 190.484 119.085L116.722 247.228Z" fill="url(#paint2_radial_30_25)"/>
<path d="M116.722 247.228C113.004 253.687 103.684 253.687 99.9661 247.228L26.2042 119.085C22.4947 112.64 27.1462 104.596 34.5821 104.596L182.106 104.596C189.542 104.596 194.193 112.64 190.484 119.085L116.722 247.228Z" fill="url(#paint3_radial_30_25)" fill-opacity="0.5"/>
<path d="M100.804 246.745L27.042 118.602C23.7034 112.802 27.8898 105.562 34.5821 105.562L182.106 105.562C188.798 105.562 192.985 112.802 189.646 118.602L115.884 246.745C112.538 252.558 104.15 252.558 100.804 246.745Z" fill="url(#paint4_radial_30_25)" fill-opacity="0.5" stroke="url(#paint5_linear_30_25)" stroke-width="1.93333" stroke-linejoin="round"/>
<defs>
<linearGradient id="paint0_linear_30_25" x1="241.666" y1="264.867" x2="88.9331" y2="7.73334" gradientUnits="userSpaceOnUse">
<stop stop-color="#00996C"/>
<stop offset="1" stop-color="#7AFFD8"/>
</linearGradient>
<linearGradient id="paint1_linear_30_25" x1="192.366" y1="289.033" x2="233.933" y2="42.5333" gradientUnits="userSpaceOnUse">
<stop stop-color="white" stop-opacity="0.56"/>
<stop offset="0.494792" stop-color="white" stop-opacity="0"/>
<stop offset="1" stop-color="white"/>
</linearGradient>
<radialGradient id="paint2_radial_30_25" cx="0" cy="0" r="1" gradientUnits="userSpaceOnUse" gradientTransform="translate(185.6 110.2) rotate(147.858) scale(129.006 128.619)">
<stop offset="0.48614" stop-color="#00C58A"/>
<stop offset="1" stop-color="white" stop-opacity="0.21"/>
</radialGradient>
<radialGradient id="paint3_radial_30_25" cx="0" cy="0" r="1" gradientUnits="userSpaceOnUse" gradientTransform="translate(108.266 160.467) rotate(90) scale(191.4 190.827)">
<stop stop-color="white" stop-opacity="0"/>
<stop offset="1" stop-color="white"/>
</radialGradient>
<radialGradient id="paint4_radial_30_25" cx="0" cy="0" r="1" gradientUnits="userSpaceOnUse" gradientTransform="translate(108.266 181.733) rotate(-90) scale(129.533 129.145)">
<stop stop-color="white" stop-opacity="0"/>
<stop offset="1" stop-color="white"/>
</radialGradient>
<linearGradient id="paint5_linear_30_25" x1="105.366" y1="105.367" x2="105.366" y2="261" gradientUnits="userSpaceOnUse">
<stop stop-color="white" stop-opacity="0.6"/>
<stop offset="0.494792" stop-color="white" stop-opacity="0"/>
<stop offset="1" stop-color="white" stop-opacity="0.38"/>
</linearGradient>
</defs>
</svg>

After

Width:  |  Height:  |  Size: 3.2 KiB

View File

@@ -0,0 +1,7 @@
<template>
<UBanner icon="i-lucide-construction" :actions="[{ label: 'Go to Nuxt UI v2', to: 'https://ui.nuxt.com', trailingIcon: 'i-lucide-arrow-right' }]" :close="false">
<template #title>
You're looking at the documentation for <span class="font-semibold">Nuxt UI v3</span>!
</template>
</UBanner>
</template>

View File

@@ -0,0 +1,71 @@
<script setup lang="ts">
const route = useRoute()
// const items = [{
// label: 'Figma Kit',
// to: 'https://www.figma.com/community/file/1288455405058138934',
// target: '_blank'
// }, {
// label: 'Playground',
// to: 'https://stackblitz.com/edit/nuxt-ui',
// target: '_blank'
// }, {
// label: 'Roadmap',
// to: '/roadmap'
// }, {
// label: 'Releases',
// to: '/releases'
// }]
</script>
<template>
<USeparator icon="i-simple-icons-nuxtdotjs" class="h-px" />
<UFooter>
<template #left>
<NuxtLink v-if="route.path.startsWith('/pro')" to="https://ui.nuxt.com/pro/purchase" target="_blank" class="text-sm text-[var(--ui-text-muted)]">
Purchase <span class="text-[var(--ui-text-highlighted)]">Nuxt UI Pro</span>
</NuxtLink>
<NuxtLink v-else to="https://github.com/nuxt/ui" target="_blank" class="text-sm text-[var(--ui-text-muted)]">
Published under <span class="text-[var(--ui-text-highlighted)]">MIT License</span>
</NuxtLink>
</template>
<!-- <UNavigationMenu :items="items" variant="link" color="neutral" /> -->
<template #right>
<UButton
aria-label="Nuxt Website"
icon="i-simple-icons-nuxtdotjs"
to="https://nuxt.com"
target="_blank"
color="neutral"
variant="ghost"
/>
<UButton
aria-label="Nuxt UI on Discord"
icon="i-simple-icons-discord"
to="https://chat.nuxt.dev"
target="_blank"
color="neutral"
variant="ghost"
/>
<UButton
aria-label="Nuxt on X"
icon="i-simple-icons-x"
to="https://x.com/nuxt_js"
target="_blank"
color="neutral"
variant="ghost"
/>
<UButton
aria-label="Nuxt UI on GitHub"
icon="i-simple-icons-github"
to="https://github.com/nuxt/ui"
target="_blank"
color="neutral"
variant="ghost"
/>
</template>
</UFooter>
</template>

View File

@@ -0,0 +1,23 @@
<script setup lang="ts">
const { framework, frameworks } = useSharedData()
const value = ref<string | undefined>(undefined)
onMounted(() => {
value.value = framework.value
})
</script>
<template>
<UTabs
v-model="value"
:items="frameworks"
:content="false"
color="neutral"
:ui="{
indicator: 'bg-[var(--ui-bg)]',
trigger: 'px-1 data-[state=active]:text-[var(--ui-text-highlighted)]'
}"
@update:model-value="(framework = $event as string)"
/>
</template>

View File

@@ -0,0 +1,86 @@
<script setup lang="ts">
import type { ContentNavigationItem } from '@nuxt/content'
import type { NavigationMenuItem } from '@nuxt/ui'
const props = defineProps<{
links: NavigationMenuItem[]
}>()
const config = useRuntimeConfig().public
const { module } = useSharedData()
const navigation = inject<Ref<ContentNavigationItem[]>>('navigation')
const items = computed(() => props.links.map(({ icon, ...link }) => link))
defineShortcuts({
meta_g: () => {
window.open('https://github.com/nuxt/ui/tree/v3', '_blank')
}
})
</script>
<template>
<UHeader :ui="{ left: 'min-w-0', toggle: '-mr-1.5' }" mode="drawer" :menu="{ shouldScaleBackground: true }">
<template #left>
<NuxtLink to="/" class="flex items-end gap-2 font-bold text-xl text-[var(--ui-text-highlighted)] min-w-0 focus-visible:outline-[var(--ui-primary)] shrink-0" aria-label="Nuxt UI">
<LogoPro class="w-auto h-6 shrink-0 ui-pro-only" />
<Logo class="w-auto h-6 shrink-0 ui-only" />
</NuxtLink>
<UDropdownMenu
v-slot="{ open }"
:modal="false"
:items="[{ label: `v${config.version}`, active: true, color: 'primary', checked: true, type: 'checkbox' }, { label: module === 'ui-pro' ? 'v1.5' : 'v2.19', to: module === 'ui-pro' ? 'https://ui.nuxt.com/pro' : 'https://ui.nuxt.com' }]"
:ui="{ content: 'w-(--reka-dropdown-menu-trigger-width) min-w-0' }"
size="xs"
>
<UButton
:label="`v${config.version}`"
variant="subtle"
trailing-icon="i-lucide-chevron-down"
size="xs"
class="-mb-[6px] font-semibold rounded-full truncate"
:class="[open && 'bg-[var(--ui-primary)]/15 ']"
:ui="{
trailingIcon: ['transition-transform duration-200', open ? 'rotate-180' : undefined].filter(Boolean).join(' ')
}"
/>
</UDropdownMenu>
</template>
<UNavigationMenu :items="items" variant="link" />
<template #right>
<ThemePicker />
<UTooltip text="Search" :kbds="['meta', 'K']">
<UContentSearchButton />
</UTooltip>
<UTooltip text="Open on GitHub" :kbds="['meta', 'G']" class="hidden lg:flex">
<UButton
color="neutral"
variant="ghost"
to="https://github.com/nuxt/ui"
target="_blank"
icon="i-simple-icons-github"
aria-label="GitHub"
/>
</UTooltip>
</template>
<template #content>
<UNavigationMenu orientation="vertical" :items="links" class="-mx-2.5" />
<USeparator type="dashed" class="mt-4 mb-6" />
<div class="flex flex-col gap-2 w-[calc(100%+1.25rem)] mb-5.5 -mx-2.5">
<ModuleSelect />
<FrameworkSelect />
</div>
<UContentNavigation :navigation="navigation" highlight />
</template>
</UHeader>
</template>

View File

@@ -4,8 +4,8 @@
<path d="M726 92H739C742.314 92 745 89.3137 745 86V60H773V92H800V116H773V159C773 169.5 778.057 174 787 174H800V200H783C759.948 200 745 185.071 745 160V116H726V92Z" fill="currentColor" />
<path d="M591 92V154C591 168.004 585.742 179.809 578 188C570.258 196.191 559.566 200 545 200C530.434 200 518.742 196.191 511 188C503.389 179.809 498 168.004 498 154V92H514C517.412 92 520.769 92.622 523 95C525.231 97.2459 526 98.5652 526 102V154C526 162.059 526.457 167.037 530 171C533.543 174.831 537.914 176 545 176C552.217 176 555.457 174.831 559 171C562.543 167.037 563 162.059 563 154V102C563 98.5652 563.769 96.378 566 94C567.96 91.9107 570.028 91.9599 573 92C573.411 92.0055 574.586 92 575 92H591Z" fill="currentColor" />
<path d="M676 144L710 92H684C680.723 92 677.812 93.1758 676 96L660 120L645 97C643.188 94.1758 639.277 92 636 92H611L645 143L608 200H634C637.25 200 640.182 196.787 642 194L660 167L679 195C680.818 197.787 683.75 200 687 200H713L676 144Z" fill="currentColor" />
<path d="M168 200H279C282.542 200 285.932 198.756 289 197C292.068 195.244 295.23 193.041 297 190C298.77 186.959 300.002 183.51 300 179.999C299.998 176.488 298.773 173.04 297 170.001L222 41C220.23 37.96 218.067 35.7552 215 34C211.933 32.2448 207.542 31 204 31C200.458 31 197.067 32.2448 194 34C190.933 35.7552 188.77 37.96 187 41L168 74L130 9.99764C128.228 6.95784 126.068 3.75491 123 2C119.932 0.245087 116.542 0 113 0C109.458 0 106.068 0.245087 103 2C99.9323 3.75491 96.7717 6.95784 95 9.99764L2 170.001C0.226979 173.04 0.00154312 176.488 1.90993e-06 179.999C-0.0015393 183.51 0.229648 186.959 2 190C3.77035 193.04 6.93245 195.244 10 197C13.0675 198.756 16.4578 200 20 200H90C117.737 200 137.925 187.558 152 164L186 105L204 74L259 168H186L168 200ZM89 168H40L113 42L150 105L125.491 147.725C116.144 163.01 105.488 168 89 168Z" fill="rgb(var(--color-primary-DEFAULT))" />
<path d="M958 60.0001H938C933.524 60.0001 929.926 59.9395 927 63C924.074 65.8905 925 67.5792 925 72V141C925 151.372 923.648 156.899 919 162C914.352 166.931 908.468 169 899 169C889.705 169 882.648 166.931 878 162C873.352 156.899 873 151.372 873 141V72.0001C873 67.5793 872.926 65.8906 870 63.0001C867.074 59.9396 863.476 60.0001 859 60.0001H840V141C840 159.023 845.016 173.458 855 184C865.156 194.542 879.893 200 899 200C918.107 200 932.844 194.542 943 184C953.156 173.458 958 159.023 958 141V60.0001Z" fill="rgb(var(--color-primary-DEFAULT))" />
<path fill-rule="evenodd" clip-rule="evenodd" d="M1000 60.0233L1020 60V77L1020 128V156.007L1020 181L1020 189.004C1020 192.938 1019.98 194.429 1017 197.001C1014.02 199.725 1009.56 200 1005 200H986.001V181.006L986 130.012V70.0215C986 66.1576 986.016 64.5494 989 62.023C991.819 59.6358 995.437 60.0233 1000 60.0233Z" fill="rgb(var(--color-primary-DEFAULT))" />
<path d="M168 200H279C282.542 200 285.932 198.756 289 197C292.068 195.244 295.23 193.041 297 190C298.77 186.959 300.002 183.51 300 179.999C299.998 176.488 298.773 173.04 297 170.001L222 41C220.23 37.96 218.067 35.7552 215 34C211.933 32.2448 207.542 31 204 31C200.458 31 197.067 32.2448 194 34C190.933 35.7552 188.77 37.96 187 41L168 74L130 9.99764C128.228 6.95784 126.068 3.75491 123 2C119.932 0.245087 116.542 0 113 0C109.458 0 106.068 0.245087 103 2C99.9323 3.75491 96.7717 6.95784 95 9.99764L2 170.001C0.226979 173.04 0.00154312 176.488 1.90993e-06 179.999C-0.0015393 183.51 0.229648 186.959 2 190C3.77035 193.04 6.93245 195.244 10 197C13.0675 198.756 16.4578 200 20 200H90C117.737 200 137.925 187.558 152 164L186 105L204 74L259 168H186L168 200ZM89 168H40L113 42L150 105L125.491 147.725C116.144 163.01 105.488 168 89 168Z" fill="var(--ui-primary)" />
<path d="M958 60.0001H938C933.524 60.0001 929.926 59.9395 927 63C924.074 65.8905 925 67.5792 925 72V141C925 151.372 923.648 156.899 919 162C914.352 166.931 908.468 169 899 169C889.705 169 882.648 166.931 878 162C873.352 156.899 873 151.372 873 141V72.0001C873 67.5793 872.926 65.8906 870 63.0001C867.074 59.9396 863.476 60.0001 859 60.0001H840V141C840 159.023 845.016 173.458 855 184C865.156 194.542 879.893 200 899 200C918.107 200 932.844 194.542 943 184C953.156 173.458 958 159.023 958 141V60.0001Z" fill="var(--ui-primary)" />
<path fill-rule="evenodd" clip-rule="evenodd" d="M1000 60.0233L1020 60V77L1020 128V156.007L1020 181L1020 189.004C1020 192.938 1019.98 194.429 1017 197.001C1014.02 199.725 1009.56 200 1005 200H986.001V181.006L986 130.012V70.0215C986 66.1576 986.016 64.5494 989 62.023C991.819 59.6358 995.437 60.0233 1000 60.0233Z" fill="var(--ui-primary)" />
</svg>
</template>

View File

@@ -0,0 +1,14 @@
<template>
<svg width="1352" height="200" viewBox="0 0 1352 200" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M377 200C379.16 200 381 198.209 381 196V103C381 103 386 112 395 127L434 194C435.785 197.74 439.744 200 443 200H470V50H443C441.202 50 439 51.4941 439 54V148L421 116L385 55C383.248 51.8912 379.479 50 376 50H350V200H377Z" fill="currentColor" />
<path d="M726 92H739C742.314 92 745 89.3137 745 86V60H773V92H800V116H773V159C773 169.5 778.057 174 787 174H800V200H783C759.948 200 745 185.071 745 160V116H726V92Z" fill="currentColor" />
<path d="M591 92V154C591 168.004 585.742 179.809 578 188C570.258 196.191 559.566 200 545 200C530.434 200 518.742 196.191 511 188C503.389 179.809 498 168.004 498 154V92H514C517.412 92 520.769 92.622 523 95C525.231 97.2459 526 98.5652 526 102V154C526 162.059 526.457 167.037 530 171C533.543 174.831 537.914 176 545 176C552.217 176 555.457 174.831 559 171C562.543 167.037 563 162.059 563 154V102C563 98.5652 563.769 96.378 566 94C567.96 91.9107 570.028 91.9599 573 92C573.411 92.0055 574.586 92 575 92H591Z" fill="currentColor" />
<path d="M676 144L710 92H684C680.723 92 677.812 93.1758 676 96L660 120L645 97C643.188 94.1758 639.277 92 636 92H611L645 143L608 200H634C637.25 200 640.182 196.787 642 194L660 167L679 195C680.818 197.787 683.75 200 687 200H713L676 144Z" fill="currentColor" />
<path d="M168 200H279C282.542 200 285.932 198.756 289 197C292.068 195.244 295.23 193.041 297 190C298.77 186.959 300.002 183.51 300 179.999C299.998 176.488 298.773 173.04 297 170.001L222 41C220.23 37.96 218.067 35.7552 215 34C211.933 32.2448 207.542 31 204 31C200.458 31 197.067 32.2448 194 34C190.933 35.7552 188.77 37.96 187 41L168 74L130 9.99764C128.228 6.95784 126.068 3.75491 123 2C119.932 0.245087 116.542 0 113 0C109.458 0 106.068 0.245087 103 2C99.9323 3.75491 96.7717 6.95784 95 9.99764L2 170.001C0.226979 173.04 0.00154312 176.488 1.90993e-06 179.999C-0.0015393 183.51 0.229648 186.959 2 190C3.77035 193.04 6.93245 195.244 10 197C13.0675 198.756 16.4578 200 20 200H90C117.737 200 137.925 187.558 152 164L186 105L204 74L259 168H186L168 200ZM89 168H40L113 42L150 105L125.491 147.725C116.144 163.01 105.488 168 89 168Z" fill="var(--ui-primary)" />
<path d="M958 60.0001H938C933.524 60.0001 929.926 59.9395 927 63C924.074 65.8905 925 67.5792 925 72V141C925 151.372 923.648 156.899 919 162C914.352 166.931 908.468 169 899 169C889.705 169 882.648 166.931 878 162C873.352 156.899 873 151.372 873 141V72.0001C873 67.5793 872.926 65.8906 870 63.0001C867.074 59.9396 863.476 60.0001 859 60.0001H840V141C840 159.023 845.016 173.458 855 184C865.156 194.542 879.893 200 899 200C918.107 200 932.844 194.542 943 184C953.156 173.458 958 159.023 958 141V60.0001Z" fill="currentColor" />
<path fill-rule="evenodd" clip-rule="evenodd" d="M1000 60.0233L1020 60V77L1020 128V156.007L1020 181L1020 189.004C1020 192.938 1019.98 194.429 1017 197.001C1014.02 199.725 1009.56 200 1005 200H986.001V181.006L986 130.012V70.0215C986 66.1576 986.016 64.5494 989 62.023C991.819 59.6358 995.437 60.0233 1000 60.0233Z" fill="currentColor" />
<path d="M1060 200V60H1117C1126.67 60 1134.98 61.2896 1142 65C1149.16 68.7104 1155.29 74.3744 1159 81C1162.71 87.6256 1164 95.3867 1164 104C1164 112.481 1162.71 120.374 1159 127C1155.29 133.626 1149.16 138.157 1142 142C1134.98 145.71 1126.67 148 1117 148H1090V200H1060ZM1115 123C1121.63 123 1126.69 121.578 1130 118C1133.31 114.29 1135 109.433 1135 104C1135 98.567 1133.31 93.5778 1130 90C1126.69 86.2896 1121.63 85 1115 85H1090V123H1115Z" fill="var(--ui-primary)" />
<path d="M1226 123C1219.37 123 1214.31 124.965 1211 130C1207.69 135.035 1206 142.122 1206 151V200H1178V100H1200C1203.31 100 1206 102.686 1206 106V116C1208.65 109.904 1211.16 106.518 1215 104C1218.98 101.482 1224.77 100 1231 100H1242V123H1226Z" fill="var(--ui-primary)" />
<path d="M1299 200C1288.93 200 1280.08 197.373 1272 193C1263.92 188.495 1257.51 182.818 1253 175C1248.49 167.049 1246 157.806 1246 148C1246 138.194 1248.49 129.818 1253 122C1257.51 114.049 1263.92 107.373 1272 103C1280.08 98.4946 1288.93 97 1299 97C1309.07 97 1318.92 98.4946 1327 103C1335.08 107.373 1340.49 114.049 1345 122C1349.51 129.818 1352 138.194 1352 148C1352 157.806 1349.51 167.049 1345 175C1340.49 182.818 1335.08 188.495 1327 193C1318.92 197.373 1309.07 200 1299 200ZM1299 176C1306.42 176 1312.36 173.168 1317 168C1321.64 162.832 1324 156.216 1324 148C1324 139.652 1321.64 133.168 1317 128C1312.36 122.832 1306.42 120 1299 120C1291.58 120 1285.64 122.832 1281 128C1276.36 133.168 1274 139.652 1274 148C1274 156.216 1276.36 162.832 1281 168C1285.64 173.168 1291.58 176 1299 176Z" fill="var(--ui-primary)" />
</svg>
</template>

View File

@@ -0,0 +1,20 @@
<script setup lang="ts">
const { module, modules } = useSharedData()
const value = ref<string | undefined>(undefined)
onMounted(() => {
value.value = module.value
})
</script>
<template>
<UTabs
v-model="value"
:items="modules"
:content="false"
color="neutral"
:ui="{ indicator: 'bg-[var(--ui-bg)]', trigger: 'px-1 data-[state=active]:text-[var(--ui-text-highlighted)]' }"
@update:model-value="(module = $event as string)"
/>
</template>

View File

@@ -0,0 +1,332 @@
<!-- eslint-disable no-useless-escape -->
<script setup lang="ts">
import json5 from 'json5'
import { upperFirst, camelCase, kebabCase } from 'scule'
import { hash } from 'ohash'
import { CalendarDate } from '@internationalized/date'
import * as theme from '#build/ui'
import { get, set } from '#ui/utils'
interface Cast {
get: (args: any) => any
template: (args: any) => string
}
type CastDateValue = [number, number, number]
const castMap: Record<string, Cast> = {
'DateValue': {
get: (args: CastDateValue) => new CalendarDate(...args),
template: (value: CalendarDate) => {
return value ? `new CalendarDate(${value.year}, ${value.month}, ${value.day})` : 'null'
}
},
'DateValue[]': {
get: (args: CastDateValue[]) => args.map(date => new CalendarDate(...date)),
template: (value: CalendarDate[]) => {
return value ? `[${value.map(date => `new CalendarDate(${date.year}, ${date.month}, ${date.day})`).join(', ')}]` : '[]'
}
},
'DateRange': {
get: (args: { start: CastDateValue, end: CastDateValue }) => ({ start: new CalendarDate(...args.start), end: new CalendarDate(...args.end) }),
template: (value: { start: CalendarDate, end: CalendarDate }) => {
if (!value.start || !value.end) {
return `{ start: null, end: null }`
}
return `{ start: new CalendarDate(${value.start.year}, ${value.start.month}, ${value.start.day}), end: new CalendarDate(${value.end.year}, ${value.end.month}, ${value.end.day}) }`
}
}
}
const props = defineProps<{
/** Override the slug taken from the route */
slug?: string
class?: any
/** List of props to ignore in selection */
ignore?: string[]
/** List of props to hide from code and selection */
hide?: string[]
/** List of props to externalize in script setup */
external?: string[]
/** List of props to use with `v-model` */
model?: string[]
/** List of props to cast from code and selection */
cast?: { [key: string]: string }
/** List of items for each prop */
items?: { [key: string]: string[] }
props?: { [key: string]: any }
slots?: { [key: string]: any }
/**
* Whether to format the code with Prettier
* @defaultValue false
*/
prettier?: boolean
/**
* Whether to collapse the code block
* @defaultValue false
*/
collapse?: boolean
/**
* A list of line numbers to highlight in the code block
*/
highlights?: number[]
}>()
const route = useRoute()
const { $prettier } = useNuxtApp()
const camelName = camelCase(props.slug ?? route.params.slug?.[route.params.slug.length - 1] ?? '')
const name = `U${upperFirst(camelName)}`
const component = defineAsyncComponent(() => import(`#ui/components/${upperFirst(camelName)}.vue`))
const componentProps = reactive({
...Object.fromEntries(Object.entries(props.props || {}).map(([key, value]) => {
const cast = props.cast?.[key]
if (cast && !castMap[cast]) {
throw new Error(`Unknown cast: ${cast}`)
}
return [key, cast ? castMap[cast]!.get(value) : value]
}))
})
const componentEvents = reactive({
...Object.fromEntries((props.model || []).map(key => [`onUpdate:${key}`, (e: any) => setComponentProp(key, e)])),
...(componentProps.modelValue ? { [`onUpdate:modelValue`]: (e: any) => setComponentProp('modelValue', e) } : {})
})
function getComponentProp(name: string) {
return get(componentProps, name) ?? undefined
}
function setComponentProp(name: string, value: any) {
set(componentProps, name, value)
}
const componentTheme = (theme as any)[camelName]
const meta = await fetchComponentMeta(name as any)
function mapKeys(obj: object, parentKey = ''): any {
return Object.entries(obj || {}).flatMap(([key, value]: [string, any]) => {
if (typeof value === 'object' && !Array.isArray(value)) {
return mapKeys(value, key)
}
const fullKey = parentKey ? `${parentKey}.${key}` : key
return !props.ignore?.includes(fullKey) && !props.hide?.includes(fullKey) ? fullKey : undefined
}).filter(Boolean)
}
const options = computed(() => {
const keys = mapKeys(props.props || {})
return keys.map((key: string) => {
const prop = meta?.meta?.props?.find((prop: any) => prop.name === key)
const propItems = get(props.items, key, [])
const items = propItems.length
? propItems.map((item: any) => ({
value: item,
label: item
}))
: prop?.type === 'boolean' || prop?.type === 'boolean | undefined'
? [{ value: true, label: 'true' }, { value: false, label: 'false' }]
: Object.keys(componentTheme?.variants?.[key] || {}).map(variant => ({
value: variant,
label: variant,
chip: key.toLowerCase().endsWith('color') ? { color: variant } : undefined
}))
return {
name: key,
label: key,
type: props?.cast?.[key] ?? prop?.type,
items
}
})
})
const code = computed(() => {
let code = ''
if (props.collapse) {
code += `::code-collapse
`
}
code += `\`\`\`vue${props.highlights?.length ? ` {${props.highlights.join('-')}}` : ''}`
if (props.external?.length) {
code += `
<script setup lang="ts">
`
for (const key of props.external) {
const cast = props.cast?.[key]
const value = cast ? castMap[cast]!.template(componentProps[key]) : json5.stringify(componentProps[key], null, 2).replace(/,([ |\t\n]+[}|\]])/g, '$1')
code += `const ${key === 'modelValue' ? 'value' : key} = ref(${value})
`
}
code += `<\/script>
`
}
code += `
<template>
<${name}`
for (const [key, value] of Object.entries(componentProps)) {
if (key === 'modelValue') {
code += ` v-model="value"`
continue
}
if (props.model?.includes(key)) {
code += ` v-model:${key}="${key}"`
continue
}
if (value === undefined || value === null || value === '' || props.hide?.includes(key)) {
continue
}
const prop = meta?.meta?.props?.find((prop: any) => prop.name === key)
const name = kebabCase(key)
if (typeof value === 'boolean') {
if (value && prop?.default === 'true') {
continue
}
if (!value && (!prop?.default || prop.default === 'false')) {
continue
}
code += value ? ` ${name}` : ` :${key}="false"`
} else if (typeof value === 'object') {
const parsedValue = !props.external?.includes(key) ? json5.stringify(value, null, 2).replace(/,([ |\t\n]+[}|\])])/g, '$1') : key
code += ` :${name}="${parsedValue}"`
} else {
const propDefault = prop && (prop.default ?? prop.tags?.find(tag => tag.name === 'defaultValue')?.text ?? componentTheme?.defaultVariants?.[prop.name])
if (propDefault === value) {
continue
}
code += ` ${typeof value === 'number' ? ':' : ''}${name}="${value}"`
}
}
if (props.slots) {
code += `>`
for (const [key, value] of Object.entries(props.slots)) {
if (key === 'default') {
code += props.slots.default
} else {
code += `
<template #${key}>
${value}
</template>`
}
}
code += (Object.keys(props.slots).length > 1 ? '\n' : '') + `</${name}>`
} else {
code += ' />'
}
code += `\n</template>
\`\`\`
`
if (props.collapse) {
code += `
::`
}
return code
})
const { data: ast } = await useAsyncData(`component-code-${name}-${hash({ props: componentProps, slots: props.slots })}`, async () => {
if (!props.prettier) {
return parseMarkdown(code.value)
}
let formatted = ''
try {
formatted = await $prettier.format(code.value, {
trailingComma: 'none',
semi: false,
singleQuote: true,
printWidth: 100
})
} catch {
formatted = code.value
}
return parseMarkdown(formatted)
}, { watch: [code] })
</script>
<template>
<div class="my-5">
<div>
<div v-if="options.length" class="flex items-center gap-2.5 border border-[var(--ui-border-muted)] border-b-0 relative rounded-t-[calc(var(--ui-radius)*1.5)] px-4 py-2.5 overflow-x-auto">
<template v-for="option in options" :key="option.name">
<UFormField
:label="option.label"
size="sm"
class="inline-flex ring ring-[var(--ui-border-accented)] rounded-[var(--ui-radius)]"
:ui="{
wrapper: 'bg-[var(--ui-bg-elevated)]/50 rounded-l-[var(--ui-radius)] flex border-r border-[var(--ui-border-accented)]',
label: 'text-[var(--ui-text-muted)] px-2 py-1.5',
container: 'mt-0'
}"
>
<USelect
v-if="option.items?.length"
:model-value="getComponentProp(option.name)"
:items="option.items"
value-key="value"
color="neutral"
variant="soft"
class="rounded-[var(--ui-radius)] rounded-l-none min-w-12"
:class="[option.name.toLowerCase().endsWith('color') && 'pl-6']"
:ui="{ itemLeadingChip: 'size-2' }"
@update:model-value="setComponentProp(option.name, $event)"
>
<template v-if="option.name.toLowerCase().endsWith('color')" #leading="{ modelValue, ui }">
<UChip
v-if="modelValue"
inset
standalone
:color="(modelValue as any)"
:size="ui.itemLeadingChipSize()"
class="size-2"
/>
</template>
</USelect>
<UInput
v-else
:type="option.type?.includes('number') ? 'number' : 'text'"
:model-value="getComponentProp(option.name)"
color="neutral"
variant="soft"
:ui="{ base: 'rounded-[var(--ui-radius)] rounded-l-none min-w-12' }"
@update:model-value="setComponentProp(option.name, $event)"
/>
</UFormField>
</template>
</div>
<div v-if="component" class="flex justify-center border border-b-0 border-[var(--ui-border-muted)] relative p-4 z-[1]" :class="[!options.length && 'rounded-t-[calc(var(--ui-radius)*1.5)]', props.class]">
<component :is="component" v-bind="{ ...componentProps, ...componentEvents }">
<template v-for="slot in Object.keys(slots || {})" :key="slot" #[slot]>
<slot :name="slot" mdc-unwrap="p">
{{ slots?.[slot] }}
</slot>
</template>
</component>
</div>
</div>
<MDCRenderer v-if="ast" :body="ast.body" :data="ast.data" class="[&_pre]:!rounded-t-none [&_div.my-5]:!mt-0" />
</div>
</template>

View File

@@ -0,0 +1,37 @@
<script setup lang="ts">
import { upperFirst, camelCase } from 'scule'
const route = useRoute()
const camelName = camelCase(route.params.slug?.[route.params.slug.length - 1] ?? '')
const name = `U${upperFirst(camelName)}`
const meta = await fetchComponentMeta(name as any)
</script>
<template>
<ProseTable>
<ProseThead>
<ProseTr>
<ProseTh>
Event
</ProseTh>
<ProseTh>
Type
</ProseTh>
</ProseTr>
</ProseThead>
<ProseTbody>
<ProseTr v-for="event in (meta?.meta?.events || [])" :key="event.name">
<ProseTd>
<ProseCode>
{{ event.name }}
</ProseCode>
</ProseTd>
<ProseTd>
<HighlightInlineType v-if="event.type" :type="event.type" />
</ProseTd>
</ProseTr>
</ProseTbody>
</ProseTable>
</template>

View File

@@ -0,0 +1,180 @@
<script setup lang="ts">
import { camelCase } from 'scule'
import { get, set } from '#ui/utils'
const props = withDefaults(defineProps<{
name: string
class?: any
props?: { [key: string]: any }
/**
* Whether to format the code with Prettier
* @defaultValue false
*/
prettier?: boolean
/**
* Whether to collapse the code block
* @defaultValue false
*/
collapse?: boolean
/**
* Whether to show the preview
* When `false`, the filename will be shown instead
* @defaultValue true
*/
preview?: boolean
/**
* Whether to show the source code
* @defaultValue true
*/
source?: boolean
/**
* A list of variable props to link to the component.
*/
options?: Array<{
alias?: string
name: string
label: string
items?: any[]
default: any
multiple?: boolean
}>
/**
* A list of line numbers to highlight in the code block
*/
highlights?: number[]
}>(), {
preview: true,
source: true
})
const slots = defineSlots<{
options(props?: {}): any
}>()
const { $prettier } = useNuxtApp()
const camelName = camelCase(props.name)
const data = await fetchComponentExample(camelName)
const componentProps = reactive({ ...(props.props || {}) })
const code = computed(() => {
let code = ''
if (props.collapse) {
code += `::code-collapse
`
}
code += `\`\`\`vue ${props.preview ? '' : ` [${data.pascalName}.vue]`}${props.highlights?.length ? `{${props.highlights.join('-')}}` : ''}
${data?.code ?? ''}
\`\`\``
if (props.collapse) {
code += `
::`
}
return code
})
const { data: ast } = await useAsyncData(`component-example-${camelName}`, async () => {
if (!props.prettier) {
return parseMarkdown(code.value)
}
let formatted = ''
try {
formatted = await $prettier.format(code.value, {
trailingComma: 'none',
semi: false,
singleQuote: true,
printWidth: 100
})
} catch {
formatted = code.value
}
return parseMarkdown(formatted)
}, { watch: [code] })
const optionsValues = ref(props.options?.reduce((acc, option) => {
if (option.name) {
acc[option.alias || option.name] = option.default
}
if (option.name.toLowerCase().endsWith('color') && option.items?.length) {
option.items = option.items.map((item: any) => ({
label: item,
value: item,
chip: { color: item }
}))
}
return acc
}, {} as Record<string, any>) || {})
</script>
<template>
<div class="my-5">
<template v-if="preview">
<div class="border border-[var(--ui-border-muted)] relative z-[1]" :class="[{ 'border-b-0 rounded-t-[calc(var(--ui-radius)*1.5)]': props.source, 'rounded-[calc(var(--ui-radius)*1.5)]': !props.source }]">
<div v-if="props.options?.length || !!slots.options" class="flex gap-4 p-4 border-b border-[var(--ui-border-muted)]">
<slot name="options" />
<UFormField
v-for="option in props.options"
:key="option.name"
:label="option.label"
:name="option.name"
size="sm"
class="inline-flex ring ring-[var(--ui-border-accented)] rounded-[var(--ui-radius)]"
:ui="{
wrapper: 'bg-[var(--ui-bg-elevated)]/50 rounded-l-[var(--ui-radius)] flex border-r border-[var(--ui-border-accented)]',
label: 'text-[var(--ui-text-muted)] px-2 py-1.5',
container: 'mt-0'
}"
>
<USelectMenu
v-if="option.items?.length"
:model-value="get(optionsValues, option.name)"
:items="option.items"
:search-input="false"
:value-key="option.name.toLowerCase().endsWith('color') ? 'value' : undefined"
color="neutral"
variant="soft"
class="rounded-[var(--ui-radius)] rounded-l-none min-w-12"
:multiple="option.multiple"
:class="[option.name.toLowerCase().endsWith('color') && 'pl-6']"
:ui="{ itemLeadingChip: 'size-2' }"
@update:model-value="set(optionsValues, option.name, $event)"
>
<template v-if="option.name.toLowerCase().endsWith('color')" #leading="{ modelValue, ui }">
<UChip
inset
standalone
:color="(modelValue as any)"
:size="ui.itemLeadingChipSize()"
class="size-2"
/>
</template>
</USelectMenu>
<UInput
v-else
:model-value="get(optionsValues, option.name)"
color="neutral"
variant="soft"
:ui="{ base: 'rounded-[var(--ui-radius)] rounded-l-none min-w-12' }"
@update:model-value="set(optionsValues, option.name, $event)"
/>
</UFormField>
</div>
<div class="flex justify-center p-4" :class="props.class">
<component :is="camelName" v-bind="{ ...componentProps, ...optionsValues }" />
</div>
</div>
</template>
<MDCRenderer v-if="ast && props.source" :body="ast.body" :data="ast.data" class="[&_pre]:!rounded-t-none [&_div.my-5]:!mt-0" />
</div>
</template>

View File

@@ -0,0 +1,110 @@
<script setup lang="ts">
import { upperFirst, camelCase } from 'scule'
import type { ComponentMeta } from 'vue-component-meta'
import * as theme from '#build/ui'
import * as themePro from '#build/ui-pro'
const props = withDefaults(defineProps<{
ignore?: string[]
pro?: boolean
}>(), {
ignore: () => [
'activeClass',
'inactiveClass',
'exactActiveClass',
'ariaCurrentValue',
'href',
'rel',
'noRel',
'prefetch',
'prefetchOn',
'noPrefetch',
'prefetchedClass',
'replace',
'exact',
'exactQuery',
'exactHash',
'external',
'onClick'
]
})
const route = useRoute()
const camelName = camelCase(route.params.slug?.[route.params.slug.length - 1] ?? '')
const name = `U${upperFirst(camelName)}`
const componentTheme = ((props.pro ? themePro : theme) as any)[camelName]
const meta = await fetchComponentMeta(name as any)
const metaProps: ComputedRef<ComponentMeta['props']> = computed(() => {
if (!meta?.meta?.props?.length) {
return []
}
return meta.meta.props.filter((prop) => {
return !props.ignore?.includes(prop.name)
}).map((prop) => {
prop.default = prop.default ?? prop.tags?.find(tag => tag.name === 'defaultValue')?.text ?? componentTheme?.defaultVariants?.[prop.name]
// @ts-expect-error - Type is not correct
prop.type = !prop.type.startsWith('boolean') && prop.schema?.kind === 'enum' && Object.keys(prop.schema.schema)?.length ? Object.values(prop.schema.schema).map(schema => schema?.type ? schema.type : schema).join(' | ') : prop.type
return prop
}).sort((a, b) => {
if (a.name === 'as') {
return -1
}
if (b.name === 'as') {
return 1
}
if (a.name === 'ui') {
return 1
}
if (b.name === 'ui') {
return -1
}
return 0
})
})
</script>
<template>
<ProseTable>
<ProseThead>
<ProseTr>
<ProseTh>
Prop
</ProseTh>
<ProseTh>
Default
</ProseTh>
<ProseTh>
Type
</ProseTh>
</ProseTr>
</ProseThead>
<ProseTbody>
<ProseTr v-for="prop in metaProps" :key="prop.name">
<ProseTd>
<ProseCode>
{{ prop.name }}
</ProseCode>
</ProseTd>
<ProseTd>
<HighlightInlineType v-if="prop.default" :type="prop.default" />
</ProseTd>
<ProseTd>
<HighlightInlineType v-if="prop.type" :type="prop.type" />
<MDC v-if="prop.description" :value="prop.description" class="text-[var(--ui-text-toned)] mt-1" />
<ComponentPropsLinks v-if="prop.tags?.length" :prop="prop" />
<ComponentPropsSchema v-if="prop.schema" :prop="prop" :ignore="ignore" />
</ProseTd>
</ProseTr>
</ProseTbody>
</ProseTable>
</template>

View File

@@ -0,0 +1,17 @@
<script setup lang="ts">
import type { PropertyMeta } from 'vue-component-meta'
const props = defineProps<{
prop: PropertyMeta
}>()
const links = computed(() => props.prop.tags?.filter((tag: any) => tag.name === 'link'))
</script>
<template>
<ProseUl v-if="links?.length">
<ProseLi v-for="link in links" :key="link.name">
<MDC :value="link.text ?? ''" class="my-1" />
</ProseLi>
</ProseUl>
</template>

View File

@@ -0,0 +1,47 @@
<script setup lang="ts">
import type { PropertyMeta } from 'vue-component-meta'
const props = defineProps<{
prop: PropertyMeta
ignore?: string[]
}>()
function getSchemaProps(schema: PropertyMeta['schema']): any {
if (!schema || typeof schema === 'string' || !schema.schema) {
return []
}
if (schema.kind === 'object') {
return Object.values(schema.schema).filter(prop => !props.ignore?.includes(prop.name))
}
return (Array.isArray(schema.schema) ? schema.schema : Object.values(schema.schema)).flatMap(getSchemaProps as any)
}
const schemaProps = computed(() => {
return getSchemaProps(props.prop.schema).map((prop: any) => {
const defaultValue = prop.default ?? prop.tags?.find((tag: any) => tag.name === 'defaultValue')?.text
let description = prop.description
if (defaultValue) {
description = description ? `${description} Defaults to \`${defaultValue}\`{lang="ts-type"}.` : `Defaults to \`${defaultValue}\`{lang="ts-type"}.`
}
return {
...prop,
description
}
})
})
</script>
<template>
<ProseCollapsible v-if="schemaProps?.length" class="mt-1">
<ProseUl>
<ProseLi v-for="schemaProp in schemaProps" :key="schemaProp.name">
<HighlightInlineType :type="`${schemaProp.name}${schemaProp.required === false ? '?' : ''}: ${schemaProp.type}`" />
<MDC v-if="schemaProp.description" :value="schemaProp.description" class="text-[var(--ui-text-muted)] my-1" />
</ProseLi>
</ProseUl>
</ProseCollapsible>
</template>

View File

@@ -0,0 +1,39 @@
<script setup lang="ts">
import { upperFirst, camelCase } from 'scule'
const route = useRoute()
const camelName = camelCase(route.params.slug?.[route.params.slug.length - 1] ?? '')
const name = `U${upperFirst(camelName)}`
const meta = await fetchComponentMeta(name as any)
</script>
<template>
<ProseTable>
<ProseThead>
<ProseTr>
<ProseTh>
Slot
</ProseTh>
<ProseTh>
Type
</ProseTh>
</ProseTr>
</ProseThead>
<ProseTbody>
<ProseTr v-for="slot in (meta?.meta?.slots || [])" :key="slot.name">
<ProseTd>
<ProseCode>
{{ slot.name }}
</ProseCode>
</ProseTd>
<ProseTd>
<HighlightInlineType v-if="slot.type" :type="slot.type" />
<MDC v-if="slot.description" :value="slot.description" class="text-[var(--ui-text-toned)] mt-1" />
</ProseTd>
</ProseTr>
</ProseTbody>
</ProseTable>
</template>

View File

@@ -0,0 +1,108 @@
<script setup lang="ts">
import json5 from 'json5'
import { camelCase } from 'scule'
import * as theme from '#build/ui'
import * as themePro from '#build/ui-pro'
const props = defineProps<{
pro?: boolean
}>()
const route = useRoute()
const { framework } = useSharedData()
const name = camelCase(route.params.slug?.[route.params.slug.length - 1] ?? '')
const strippedCompoundVariants = ref(false)
const strippedTheme = computed(() => {
const strippedTheme = {
...((props.pro ? themePro : theme) as any)[name]
}
if (strippedTheme?.compoundVariants) {
strippedTheme.compoundVariants = strippedTheme.compoundVariants.filter((compoundVariant: any) => {
if (compoundVariant.color) {
if (!['primary', 'neutral'].includes(compoundVariant.color)) {
strippedCompoundVariants.value = true
return false
}
}
if (compoundVariant.highlightColor) {
if (!['primary', 'neutral'].includes(compoundVariant.highlightColor)) {
strippedCompoundVariants.value = true
return false
}
}
if (compoundVariant.loadingColor) {
if (!['primary', 'neutral'].includes(compoundVariant.loadingColor)) {
strippedCompoundVariants.value = true
return false
}
}
return true
})
}
return strippedTheme
})
const component = computed(() => {
return {
[props.pro ? 'uiPro' : 'ui']: {
[name]: strippedTheme.value
}
}
})
const { data: ast } = await useAsyncData(`component-theme-${name}`, async () => {
const md = `
::code-collapse{class="nuxt-only"}
\`\`\`ts [app.config.ts]
export default defineAppConfig(${json5.stringify(component.value, null, 2).replace(/,([ |\t\n]+[}|\])])/g, '$1')})
\`\`\`\
::
::code-collapse{class="vue-only"}
\`\`\`ts [vite.config.ts]
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import ui from '@nuxt/ui/vite'
export default defineConfig({
plugins: [
vue(),
ui(${json5.stringify(component.value, null, 2).replace(/,([ |\t\n]+[}|\])])/g, '$1')
.split('\n')
.map((line, i) => i === 0 ? line : ` ${line}`)
.join('\n')})
]
})
\`\`\`
::
${strippedCompoundVariants.value
? `
::callout{icon="i-simple-icons-github" to="https://github.com/nuxt/ui/blob/v3/src/theme/${name}.ts"}
Some colors in \`compoundVariants\` are omitted for readability. Check out the source code on GitHub.
::`
: ''}
`
return parseMarkdown(md)
}, { watch: [framework] })
</script>
<template>
<MDCRenderer v-if="ast" :body="ast.body" :data="ast.data" />
</template>

View File

@@ -0,0 +1,12 @@
<script setup lang="ts">
import { Slot } from 'reka-ui'
</script>
<template>
<Slot class="nuxt-only">
<slot name="nuxt" />
</Slot>
<Slot class="vue-only">
<slot name="vue" />
</Slot>
</template>

View File

@@ -0,0 +1,31 @@
<script setup lang="ts">
import { murmurHash } from 'ohash'
const props = defineProps<{
type: string
}>()
const type = computed(() => {
let type = props.type
if (type.includes(', "as" | "asChild" | "forceMount">')) {
type = type.replace(`, "as" | "asChild" | "forceMount">`, ``).replace('Omit<', '')
}
if (type.includes(', "as" | "asChild">')) {
type = type.replace(', "as" | "asChild">', '').replace('Omit<', '')
}
if (type.startsWith('undefined |')) {
type = type.replace('undefined |', '')
}
if (type.endsWith('| undefined')) {
type = type.replace('| undefined', '')
}
return type
})
const { data: ast } = await useAsyncData(`hightlight-inline-code-${murmurHash(type.value)}`, () => parseMarkdown(`\`${type.value}\`{lang="ts-type"}`))
</script>
<template>
<MDCRenderer v-if="ast" :body="ast.body" :data="ast.data" />
</template>

View File

@@ -0,0 +1,69 @@
<script setup lang="ts">
import json5 from 'json5'
import icons from '../../../../src/theme/icons'
const appConfig = useAppConfig()
const { framework, module } = useSharedData()
const { data: ast } = await useAsyncData(`icons-theme`, async () => {
const md = `
::code-collapse{class="ui-only nuxt-only"}
\`\`\`ts [app.config.ts]
export default defineAppConfig(${json5.stringify({
ui: {
icons
}
}, null, 2).replace(/,([ |\t\n]+[}|\])])/g, '$1')})
\`\`\`\
::
::code-collapse{class="ui-pro-only nuxt-only"}
\`\`\`ts [app.config.ts]
export default defineAppConfig(${json5.stringify({
ui: {
icons: appConfig.ui.icons
}
}, null, 2).replace(/,([ |\t\n]+[}|\])])/g, '$1')})
\`\`\`\
::
::caution{class="ui-pro-only vue-only"}
Nuxt UI Pro v3 does not support Vue yet.
::
::code-collapse{class="vue-only"}
\`\`\`ts [vite.config.ts]
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import ui from '@nuxt/ui/vite'
export default defineConfig({
plugins: [
vue(),
ui(${json5.stringify({
ui: {
icons
}
}, null, 2).replace(/,([ |\t\n]+[}|\])])/g, '$1')
.split('\n')
.map((line, i) => i === 0 ? line : ` ${line}`)
.join('\n')})
]
})
\`\`\`
::
`
return parseMarkdown(md)
}, { watch: [framework, module] })
</script>
<template>
<MDCRenderer v-if="ast" :body="ast.body" :data="ast.data" />
</template>

View File

@@ -0,0 +1,12 @@
<script setup lang="ts">
import { Slot } from 'reka-ui'
</script>
<template>
<Slot class="ui-only">
<slot name="ui" />
</Slot>
<Slot class="ui-pro-only">
<slot name="ui-pro" />
</Slot>
</template>

View File

@@ -1,6 +1,6 @@
<template>
<div class="relative overflow-hidden rounded border border-dashed border-gray-400 dark:border-gray-500 opacity-75 px-4 flex items-center justify-center">
<svg class="absolute inset-0 h-full w-full stroke-gray-900/10 dark:stroke-white/10" fill="none">
<div class="relative overflow-hidden rounded-[var(--ui-radius)] border border-dashed border-[var(--ui-border-accented)] opacity-75 px-4 flex items-center justify-center">
<svg class="absolute inset-0 h-full w-full stroke-[var(--ui-border-inverted)]/10" fill="none">
<defs>
<pattern
id="pattern-5c1e4f0e-62d5-498b-8ff0-cf77bb448c8e"

View File

@@ -0,0 +1,66 @@
<script setup lang="ts">
import * as locales from '@nuxt/ui/locale'
const props = withDefaults(defineProps<{
default?: string
}>(), {
default: 'en'
})
function getEmojiFlag(locale: string): string {
// Map language codes to default country codes
const languageToCountry: Record<string, string> = {
en: 'gb',
ar: 'sa',
cs: 'cz',
zh: 'cn',
ja: 'jp',
ko: 'kr'
}
// Get base language code before any region specifier
const baseLanguage = locale.split('-')[0]?.toLowerCase() || locale
// Use mapped country code or extract from locale if it contains a region
const countryCode = languageToCountry[baseLanguage] || locale.replace(/^.*-/, '').slice(0, 2)
return countryCode
.split('')
.map((char: string) => {
const codePoint = char.toUpperCase().codePointAt(0)
return codePoint ? String.fromCodePoint(0x1F1A5 + codePoint) : ''
})
.join('')
}
</script>
<!-- eslint-disable vue/singleline-html-element-content-newline -->
<template>
<div>
<ProseP>
By default, the <ProseCode>{{ props.default }}</ProseCode> locale is used.
</ProseP>
<div class="grid gap-6 grid-cols-2 md:grid-cols-3">
<div v-for="locale in locales" :key="locale.code">
<div class="flex gap-3 items-center">
<UAvatar size="xl">
{{ getEmojiFlag(locale.code) }}
</UAvatar>
<div class="text-sm">
<div class="font-semibold">{{ locale.name }}</div>
<div class="mt-1">Code: <ProseCode class="text-xs">{{ locale.code }}</ProseCode></div>
</div>
</div>
</div>
</div>
<ProseNote to="https://github.com/nuxt/ui/tree/v3/src/runtime/locale" target="_blank">
If you need additional languages, you can contribute by creating a PR to add a new locale in <ProseCode>src/runtime/locale/</ProseCode>.
</ProseNote>
<ProseTip>
You can use the <ProseCode>nuxt-ui</ProseCode> CLI to create a new locale:
<ProsePre language="bash">nuxt-ui make locale --code "en" --name "English"</ProsePre>
</ProseTip>
</div>
</template>

View File

@@ -0,0 +1,24 @@
<script setup lang="ts">
const items = [
{
label: 'Icons',
icon: 'i-lucide-smile'
},
{
label: 'Colors',
icon: 'i-lucide-swatch-book'
},
{
label: 'Components',
icon: 'i-lucide-box'
}
]
</script>
<template>
<UAccordion :items="items">
<template #body="{ item }">
This is the {{ item.label }} panel.
</template>
</UAccordion>
</template>

View File

@@ -0,0 +1,26 @@
<script setup lang="ts">
const items = [
{
label: 'Icons',
icon: 'i-lucide-smile'
},
{
label: 'Colors',
icon: 'i-lucide-swatch-book'
},
{
label: 'Components',
icon: 'i-lucide-box'
}
]
</script>
<template>
<UAccordion :items="items">
<template #content="{ item }">
<p class="pb-3.5 text-sm text-[var(--ui-text-muted)]">
This is the {{ item.label }} panel.
</p>
</template>
</UAccordion>
</template>

View File

@@ -0,0 +1,30 @@
<script setup lang="ts">
const items = [
{
label: 'Icons',
icon: 'i-lucide-smile',
content: 'You have nothing to do, @nuxt/icon will handle it automatically.'
},
{
label: 'Colors',
icon: 'i-lucide-swatch-book',
slot: 'colors',
content: 'Choose a primary and a neutral color from your Tailwind CSS theme.'
},
{
label: 'Components',
icon: 'i-lucide-box',
content: 'You can customize components by using the `class` / `ui` props or in your app.config.ts.'
}
]
</script>
<template>
<UAccordion :items="items">
<template #colors="{ item }">
<p class="text-sm pb-3.5 text-[var(--ui-primary)]">
{{ item.content }}
</p>
</template>
</UAccordion>
</template>

View File

@@ -0,0 +1,32 @@
<script setup lang="ts">
const items = [
{
label: 'Icons',
icon: 'i-lucide-smile',
content: 'You have nothing to do, @nuxt/icon will handle it automatically.'
},
{
label: 'Colors',
icon: 'i-lucide-swatch-book',
content: 'Choose a primary and a neutral color from your Tailwind CSS theme.'
},
{
label: 'Components',
icon: 'i-lucide-box',
content: 'You can customize components by using the `class` / `ui` props or in your app.config.ts.'
}
]
const active = ref('0')
// Note: This is for demonstration purposes only. Don't do this at home.
onMounted(() => {
setInterval(() => {
active.value = String((Number(active.value) + 1) % items.length)
}, 2000)
})
</script>
<template>
<UAccordion v-model="active" :items="items" />
</template>

View File

@@ -0,0 +1,24 @@
<template>
<UAvatarGroup>
<UChip inset color="success">
<UAvatar
src="https://github.com/benjamincanac.png"
alt="Benjamin Canac"
/>
</UChip>
<UChip inset color="warning">
<UAvatar
src="https://github.com/romhml.png"
alt="Romain Hamel"
/>
</UChip>
<UChip inset color="error">
<UAvatar
src="https://github.com/noook.png"
alt="Neil Richter"
/>
</UChip>
</UAvatarGroup>
</template>

View File

@@ -0,0 +1,39 @@
<template>
<UAvatarGroup>
<ULink
to="https://github.com/benjamincanac"
target="_blank"
class="hover:ring-[var(--ui-primary)] transition"
raw
>
<UAvatar
src="https://github.com/benjamincanac.png"
alt="Benjamin Canac"
/>
</ULink>
<ULink
to="https://github.com/romhml"
target="_blank"
class="hover:ring-[var(--ui-primary)] transition"
raw
>
<UAvatar
src="https://github.com/romhml.png"
alt="Romain Hamel"
/>
</ULink>
<ULink
to="https://github.com/noook"
target="_blank"
class="hover:ring-[var(--ui-primary)] transition"
raw
>
<UAvatar
src="https://github.com/noook.png"
alt="Neil Richter"
/>
</ULink>
</UAvatarGroup>
</template>

View File

@@ -0,0 +1,24 @@
<template>
<UAvatarGroup>
<UTooltip text="benjamincanac">
<UAvatar
src="https://github.com/benjamincanac.png"
alt="Benjamin Canac"
/>
</UTooltip>
<UTooltip text="romhml">
<UAvatar
src="https://github.com/romhml.png"
alt="Romain Hamel"
/>
</UTooltip>
<UTooltip text="noook">
<UAvatar
src="https://github.com/noook.png"
alt="Neil Richter"
/>
</UTooltip>
</UAvatarGroup>
</template>

View File

@@ -0,0 +1,8 @@
<template>
<UChip inset>
<UAvatar
src="https://github.com/benjamincanac.png"
alt="Benjamin Canac"
/>
</UChip>
</template>

View File

@@ -0,0 +1,8 @@
<template>
<UTooltip text="Benjamin Canac">
<UAvatar
src="https://github.com/benjamincanac.png"
alt="Benjamin Canac"
/>
</UTooltip>
</template>

View File

@@ -0,0 +1,32 @@
<script setup lang="ts">
const items = [{
label: 'Home',
to: '/'
}, {
slot: 'dropdown',
icon: 'i-lucide-ellipsis',
children: [{
label: 'Documentation'
}, {
label: 'Themes'
}, {
label: 'GitHub'
}]
}, {
label: 'Components',
to: '/components'
}, {
label: 'Breadcrumb',
to: '/components/breadcrumb'
}]
</script>
<template>
<UBreadcrumb :items="items">
<template #dropdown="{ item }">
<UDropdownMenu :items="item.children">
<UButton :icon="item.icon" color="neutral" variant="link" class="p-0.5" />
</UDropdownMenu>
</template>
</UBreadcrumb>
</template>

View File

@@ -0,0 +1,20 @@
<script setup lang="ts">
const items = [{
label: 'Home',
to: '/'
}, {
label: 'Components',
to: '/components'
}, {
label: 'Breadcrumb',
to: '/components/breadcrumb'
}]
</script>
<template>
<UBreadcrumb :items="items">
<template #separator>
<span class="mx-2 text-[var(--ui-text-muted)]">/</span>
</template>
</UBreadcrumb>
</template>

View File

@@ -0,0 +1,33 @@
<script setup lang="ts">
const items = [{
label: 'Team',
icon: 'i-lucide-users'
}, {
label: 'Invite users',
icon: 'i-lucide-user-plus',
children: [{
label: 'Invite by email',
icon: 'i-lucide-send-horizontal'
}, {
label: 'Invite by link',
icon: 'i-lucide-link'
}]
}, {
label: 'New team',
icon: 'i-lucide-plus'
}]
</script>
<template>
<UButtonGroup>
<UButton color="neutral" variant="subtle" label="Settings" />
<UDropdownMenu :items="items">
<UButton
color="neutral"
variant="outline"
icon="i-lucide-chevron-down"
/>
</UDropdownMenu>
</UButtonGroup>
</template>

View File

@@ -0,0 +1,13 @@
<template>
<UButtonGroup>
<UInput color="neutral" variant="outline" placeholder="Enter token" />
<UTooltip text="Copy to clipboard">
<UButton
color="neutral"
variant="subtle"
icon="i-lucide-clipboard"
/>
</UTooltip>
</UButtonGroup>
</template>

View File

@@ -0,0 +1,11 @@
<script setup lang="ts">
async function onClick() {
return new Promise<void>(res => setTimeout(res, 1000))
}
</script>
<template>
<UButton loading-auto @click="onClick">
Button
</UButton>
</template>

View File

@@ -0,0 +1,23 @@
<script setup lang="ts">
const state = reactive({ fullName: '' })
async function onSubmit() {
return new Promise<void>(res => setTimeout(res, 1000))
}
async function validate(data: Partial<typeof state>) {
if (!data.fullName?.length) return [{ name: 'fullName', message: 'Required' }]
return []
}
</script>
<template>
<UForm :state="state" :validate="validate" @submit="onSubmit">
<UFormField name="fullName" label="Full name">
<UInput v-model="state.fullName" />
</UFormField>
<UButton type="submit" class="mt-2" loading-auto>
Submit
</UButton>
</UForm>
</template>

View File

@@ -0,0 +1,21 @@
<script setup lang="ts">
import { CalendarDate, DateFormatter, getLocalTimeZone } from '@internationalized/date'
const df = new DateFormatter('en-US', {
dateStyle: 'medium'
})
const modelValue = shallowRef(new CalendarDate(2022, 1, 10))
</script>
<template>
<UPopover>
<UButton color="neutral" variant="subtle" icon="i-lucide-calendar">
{{ df.format(modelValue.toDate(getLocalTimeZone())) }}
</UButton>
<template #content>
<UCalendar v-model="modelValue" class="p-2" />
</template>
</UPopover>
</template>

View File

@@ -0,0 +1,35 @@
<script setup lang="ts">
import { CalendarDate, DateFormatter, getLocalTimeZone } from '@internationalized/date'
const df = new DateFormatter('en-US', {
dateStyle: 'medium'
})
const modelValue = shallowRef({
start: new CalendarDate(2022, 1, 20),
end: new CalendarDate(2022, 2, 10)
})
</script>
<template>
<UPopover>
<UButton color="neutral" variant="subtle" icon="i-lucide-calendar">
<template v-if="modelValue.start">
<template v-if="modelValue.end">
{{ df.format(modelValue.start.toDate(getLocalTimeZone())) }} - {{ df.format(modelValue.end.toDate(getLocalTimeZone())) }}
</template>
<template v-else>
{{ df.format(modelValue.start.toDate(getLocalTimeZone())) }}
</template>
</template>
<template v-else>
Pick a date
</template>
</UButton>
<template #content>
<UCalendar v-model="modelValue" class="p-2" :number-of-months="2" range />
</template>
</UPopover>
</template>

View File

@@ -0,0 +1,17 @@
<script setup lang="ts">
import { CalendarDate } from '@internationalized/date'
import type { Matcher } from 'reka-ui/date'
const modelValue = shallowRef({
start: new CalendarDate(2022, 1, 1),
end: new CalendarDate(2022, 1, 9)
})
const isDateDisabled: Matcher = (date) => {
return date.day >= 10 && date.day <= 16
}
</script>
<template>
<UCalendar v-model="modelValue" :is-date-disabled="isDateDisabled" range />
</template>

View File

@@ -0,0 +1,30 @@
<script setup lang="ts">
import { CalendarDate } from '@internationalized/date'
const modelValue = shallowRef(new CalendarDate(2022, 1, 10))
function getColorByDate(date: Date) {
const isWeekend = date.getDay() % 6 == 0
const isDayMeeting = date.getDay() % 3 == 0
if (isWeekend) {
return undefined
}
if (isDayMeeting) {
return 'error'
}
return 'success'
}
</script>
<template>
<UCalendar v-model="modelValue">
<template #day="{ day }">
<UChip :show="!!getColorByDate(day.toDate('UTC'))" :color="getColorByDate(day.toDate('UTC'))" size="2xs">
{{ day.day }}
</UChip>
</template>
</UCalendar>
</template>

View File

@@ -0,0 +1,11 @@
<script setup lang="ts">
import { CalendarDate } from '@internationalized/date'
const modelValue = shallowRef(new CalendarDate(2023, 9, 10))
const minDate = new CalendarDate(2023, 9, 1)
const maxDate = new CalendarDate(2023, 9, 30)
</script>
<template>
<UCalendar v-model="modelValue" :min-value="minDate" :max-value="maxDate" />
</template>

View File

@@ -0,0 +1,17 @@
<script setup lang="ts">
import { CalendarDate } from '@internationalized/date'
import type { Matcher } from 'reka-ui/date'
const modelValue = shallowRef({
start: new CalendarDate(2022, 1, 1),
end: new CalendarDate(2022, 1, 9)
})
const isDateUnavailable: Matcher = (date) => {
return date.day >= 10 && date.day <= 16
}
</script>
<template>
<UCalendar v-model="modelValue" :is-date-unavailable="isDateUnavailable" range />
</template>

View File

@@ -0,0 +1,16 @@
<script setup lang="ts">
const items = [
'https://picsum.photos/640/640?random=1',
'https://picsum.photos/640/640?random=2',
'https://picsum.photos/640/640?random=3',
'https://picsum.photos/640/640?random=4',
'https://picsum.photos/640/640?random=5',
'https://picsum.photos/640/640?random=6'
]
</script>
<template>
<UCarousel v-slot="{ item }" arrows :items="items" class="w-full max-w-xs mx-auto">
<img :src="item" width="320" height="320" class="rounded-lg">
</UCarousel>
</template>

View File

@@ -0,0 +1,29 @@
<script setup lang="ts">
const items = [
'https://picsum.photos/640/640?random=1',
'https://picsum.photos/640/320?random=2',
'https://picsum.photos/640/640?random=3',
'https://picsum.photos/640/320?random=4',
'https://picsum.photos/640/640?random=5',
'https://picsum.photos/640/320?random=6'
]
</script>
<template>
<UCarousel
v-slot="{ item }"
auto-height
arrows
dots
:items="items"
:ui="{
container: 'transition-[height]',
controls: 'absolute -top-8 inset-x-12',
dots: '-top-7',
dot: 'w-6 h-1'
}"
class="w-full max-w-xs mx-auto"
>
<img :src="item" width="320" height="320" class="rounded-lg">
</UCarousel>
</template>

View File

@@ -0,0 +1,24 @@
<script setup lang="ts">
const items = [
'https://picsum.photos/468/468?random=1',
'https://picsum.photos/468/468?random=2',
'https://picsum.photos/468/468?random=3',
'https://picsum.photos/468/468?random=4',
'https://picsum.photos/468/468?random=5',
'https://picsum.photos/468/468?random=6'
]
</script>
<template>
<UCarousel
v-slot="{ item }"
loop
dots
arrows
auto-scroll
:items="items"
:ui="{ item: 'basis-1/3' }"
>
<img :src="item" width="234" height="234" class="rounded-lg">
</UCarousel>
</template>

View File

@@ -0,0 +1,24 @@
<script setup lang="ts">
const items = [
'https://picsum.photos/468/468?random=1',
'https://picsum.photos/468/468?random=2',
'https://picsum.photos/468/468?random=3',
'https://picsum.photos/468/468?random=4',
'https://picsum.photos/468/468?random=5',
'https://picsum.photos/468/468?random=6'
]
</script>
<template>
<UCarousel
v-slot="{ item }"
loop
arrows
dots
:autoplay="{ delay: 2000 }"
:items="items"
:ui="{ item: 'basis-1/3' }"
>
<img :src="item" width="234" height="234" class="rounded-lg">
</UCarousel>
</template>

View File

@@ -0,0 +1,25 @@
<script setup lang="ts">
const items = [
'https://picsum.photos/528/528?random=1',
'https://picsum.photos/528/528?random=2',
'https://picsum.photos/528/528?random=3',
'https://picsum.photos/528/528?random=4',
'https://picsum.photos/528/528?random=5',
'https://picsum.photos/528/528?random=6'
]
</script>
<template>
<UCarousel
v-slot="{ item }"
class-names
arrows
:items="items"
:ui="{
item: 'basis-[70%] transition-opacity [&:not(.is-snapped)]:opacity-10'
}"
class="mx-auto max-w-sm"
>
<img :src="item" width="264" height="264" class="rounded-lg">
</UCarousel>
</template>

Some files were not shown because too many files have changed in this diff Show More