Compare commits

..

903 Commits

Author SHA1 Message Date
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
820 changed files with 53728 additions and 39044 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,45 +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 }],
// 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: ["bug"]
labels: ["triage", "bug"]
body:
- type: markdown
attributes:

View File

@@ -4,5 +4,5 @@ contact_links:
url: https://ui.nuxt.com
about: Check the documentation for guides and examples.
- name: 📚 Discord
url: https://discord.com/channels/473401852243869706/1153996761426300948
about: Consider asking questions in the `#ui` channel.
url: https://go.nuxt.com/discord
about: Consider asking questions in the help channel.

View File

@@ -1,6 +1,6 @@
name: "🚀 Feature request"
description: Suggest an idea or enhancement for the module.
labels: ["enhancement"]
labels: ["triage", "enhancement"]
body:
- type: markdown
attributes:

View File

@@ -1,87 +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: [18]
env:
NUXT_GITHUB_TOKEN: ${{ secrets.NUXT_GITHUB_TOKEN }}
steps:
- uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node }}
- name: checkout
uses: actions/checkout@master
- uses: pnpm/action-setup@v2
name: Install pnpm
id: pnpm-install
with:
version: 8
run_install: false
- name: Get pnpm store directory
id: pnpm-cache
shell: bash
run: |
echo "STORE_PATH=$(pnpm store path)" >> $GITHUB_OUTPUT
- uses: actions/cache@v4
name: Setup pnpm cache
with:
path: ${{ steps.pnpm-cache.outputs.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-pnpm-store-
- 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}}

56
.github/workflows/ci-v3.yml vendored Normal file
View File

@@ -0,0 +1,56 @@
name: ci-v3
on:
push:
branches:
- 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
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: 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: Test
run: pnpm run test
- name: Build
run: pnpm run build

View File

@@ -1,77 +0,0 @@
name: ci-main
on:
push:
branches:
- main
jobs:
ci:
runs-on: ${{ matrix.os }}
strategy:
matrix:
os: [ubuntu-latest] # macos-latest, windows-latest
node: [18]
env:
NUXT_GITHUB_TOKEN: ${{ secrets.NUXT_GITHUB_TOKEN }}
steps:
- uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node }}
- name: checkout
uses: actions/checkout@master
- uses: pnpm/action-setup@v2
name: Install pnpm
id: pnpm-install
with:
version: 8
run_install: false
- name: Get pnpm store directory
id: pnpm-cache
shell: bash
run: |
echo "STORE_PATH=$(pnpm store path)" >> $GITHUB_OUTPUT
- uses: actions/cache@v4
name: Setup pnpm cache
with:
path: ${{ steps.pnpm-cache.outputs.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-pnpm-store-
- 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: 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 }}

23
.github/workflows/stale.yml vendored Normal file
View File

@@ -0,0 +1,23 @@
name: stale
on:
schedule:
- cron: '30 1 * * *'
jobs:
stale:
runs-on: ubuntu-latest
permissions:
issues: write
pull-requests: write
steps:
- uses: actions/stale@v9
with:
exempt-issue-labels: triage,v3
stale-issue-message: 'This issue is stale because it has been open for 30 days with no activity.'
stale-issue-label: stale
stale-pr-label: stale
days-before-stale: 30
days-before-close: -1

32
.gitignore vendored
View File

@@ -1,12 +1,24 @@
node_modules
*.log
.nuxt
nuxt.d.ts
# 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

View File

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

View File

@@ -3,17 +3,6 @@
"commitMessage": "chore(release): v${version}",
"tagName": "v${version}"
},
"npm": {
"publish": false
},
"github": {
"release": true,
"releaseName": "v${version}",
"web": true
},
"hooks": {
"before:init": ["pnpm lint", "pnpm typecheck"]
},
"plugins": {
"@release-it/conventional-changelog": {
"preset": {

View File

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

View File

@@ -1,37 +1,271 @@
# Changelog
## [2.15.2](https://github.com/nuxt/ui/compare/v2.15.1...v2.15.2) (2024-04-12)
## [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
* **Accordion:** add `unmount` prop to allow lazy mounting for heavy components ([#1590](https://github.com/nuxt/ui/issues/1590)) ([91e5002](https://github.com/nuxt/ui/commit/91e50020507ac66992dfb52b3e0ad1a1ae5614b5))
* **Table:** add `checkbox` ui config ([#1409](https://github.com/nuxt/ui/issues/1409)) ([8b54660](https://github.com/nuxt/ui/commit/8b546600dbfbff187d9c5be1b35ea1772e94f83f))
* **module:** hard-code css file to be imported anywhere ([62a2643](https://github.com/nuxt/ui/commit/62a2643a80e7ab6c6e154ba59801d393d9a53c40))
### Bug Fixes
* **Breadcrumb:** missing `min-w-0` on wrapper to truncate ([9f01145](https://github.com/nuxt/ui/commit/9f01145bc674378371ff34d7110f3235b57d2459)), closes [#1650](https://github.com/nuxt/ui/issues/1650)
* **Carousel:** next and prev buttons disabled ([#1619](https://github.com/nuxt/ui/issues/1619)) ([e909884](https://github.com/nuxt/ui/commit/e909884d0327bfd7b4d5551382123f8998beff6a))
* **Popover/Dropdown:** prevent unintended closure on touchstart in mobile devices ([#1609](https://github.com/nuxt/ui/issues/1609)) ([2392b4a](https://github.com/nuxt/ui/commit/2392b4aa405430fc22766f130448a7cc5ced9a3a))
* **Slideover:** remove dynamic component when closing ([#1615](https://github.com/nuxt/ui/issues/1615)) ([58faa10](https://github.com/nuxt/ui/commit/58faa1053b9be3f627c3fcff1bcaa14850bb9e7f))
* **Slideover:** wait for transition to complete to reset state ([#1624](https://github.com/nuxt/ui/issues/1624)) ([07a4d13](https://github.com/nuxt/ui/commit/07a4d13c0fcb05c87fb42e02a3a2d6c5c52ccf09))
* **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))
## [2.15.1](https://github.com/nuxt/ui/compare/v2.15.0...v2.15.1) (2024-04-02)
## [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
* **Avatar:** add `as` prop to use `NuxtImg` underneath ([49b73aa](https://github.com/nuxt/ui/commit/49b73aa024be14a9aa150a2804f4dcb18542fa49)), closes [#1577](https://github.com/nuxt/ui/issues/1577)
* **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
* **Checkbox:** `[@change](https://github.com/change)` event value ([#1580](https://github.com/nuxt/ui/issues/1580)) ([c98d6e3](https://github.com/nuxt/ui/commit/c98d6e31c0e3f46b97957d5cf3de7f9da1f70c58))
* **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.15.0](https://github.com/nuxt/ui/compare/v2.14.2...v2.15.0) (2024-03-26)

View File

@@ -27,7 +27,14 @@ Read more on [ui.nuxt.com](https://ui.nuxt.com)
## Installation
```bash
npx nuxi@latest module add ui
# npm
npm install @nuxt/ui
# yarn
yarn add @nuxt/ui
# pnpm
pnpm add @nuxt/ui
# bun
bun add @nuxt/ui
```
Then, register the module in your `nuxt.config.ts`:
@@ -87,7 +94,7 @@ Licensed under the [MIT license](https://github.com/nuxt/ui/blob/dev/LICENSE.md)
[npm-downloads-href]: https://npmjs.com/package/@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/main/LICENSE.md
[nuxt-src]: https://img.shields.io/badge/Nuxt-18181B?logo=nuxt.js
[nuxt-href]: https://nuxt.com

83
cli/commands/init.mjs Normal file
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: 'init',
description: 'Init 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.d.ts')
await appendFile(typesPath, `export * from '../components/${args.content ? 'content/' : ''}${splitByCase(name).map(p => upperFirst(p)).join('')}.vue'`)
await sortFile(typesPath)
}
}
})

15
cli/index.mjs Executable file
View File

@@ -0,0 +1,15 @@
#!/usr/bin/env node
import { defineCommand, runMain } from 'citty'
import init from './commands/init.mjs'
const main = defineCommand({
meta: {
name: 'nuxt-ui',
description: 'Nuxt UI CLI'
},
subCommands: {
init
}
})
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"
}
}

171
cli/templates.mjs Normal file
View File

@@ -0,0 +1,171 @@
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/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 'radix-vue'
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 'radix-vue'
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 'radix-vue'
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: 'div' } }],
['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()
})
})
`
}
}
export default {
playground,
component,
theme,
test
}

17
cli/utils.mjs Normal file
View File

@@ -0,0 +1,17 @@
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')
}
}

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/dist/runtime/types'
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>

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

@@ -0,0 +1,8 @@
export default defineAppConfig({
ui: {
colors: {
primary: 'sky',
gray: 'cool'
}
}
})

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

@@ -0,0 +1,104 @@
<script setup lang="ts">
import { withoutTrailingSlash } from 'ufo'
// import { debounce } from 'perfect-debounce'
import type { ContentSearchFile } from '@nuxt/ui-pro'
const route = useRoute()
// const colorMode = useColorMode()
const runtimeConfig = useRuntimeConfig()
const { integrity, api } = runtimeConfig.public.content
const { data: navigation } = await useAsyncData('navigation', () => fetchContentNavigation(), { default: () => [] })
const { data: files } = await useLazyFetch<ContentSearchFile[]>(`${api.baseURL}/search${integrity ? '.' + integrity : ''}`, { default: () => [] })
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(() => {
return [{
label: 'Docs',
icon: 'i-heroicons-book-open',
to: '/getting-started',
active: 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-credit-card',
to: '/pro/pricing'
}, {
label: 'Templates',
icon: 'i-heroicons-computer-desktop',
to: '/pro/templates'
}]
: []), {
label: 'Releases',
icon: 'i-heroicons-rocket-launch',
to: '/releases'
}].filter(Boolean)
})
// const color = computed(() => colorMode.value === 'dark' ? '#18181b' : 'white')
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('navigation', navigation)
provide('files', files)
</script>
<template>
<UApp>
<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')" />
<LazyUContentSearch v-model:search-term="searchTerm" :files="files" :navigation="navigation" :fuse="{ resultLimit: 42 }" />
</UApp>
</template>
<style>
@import "tailwindcss";
@import "@nuxt/ui-pro";
@source "../content/**/*.md";
@theme {
--font-family-sans: 'Inter', sans-serif;
}
</style>

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-heroicons-wrench-screwdriver" :actions="[{ label: 'Go to Nuxt UI v2', to: 'https://ui.nuxt.com', trailingIcon: 'i-heroicons-arrow-right-20-solid', class: 'rounded-full' }]" :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-gray-500 dark:text-gray-400">
Purchase <span class="text-gray-900 dark:text-white">Nuxt UI Pro</span>
</NuxtLink>
<NuxtLink v-else to="https://github.com/nuxt/ui" target="_blank" class="text-sm text-gray-500 dark:text-gray-400">
Published under <span class="text-gray-900 dark:text-white">MIT License</span>
</NuxtLink>
</template>
<!-- <UNavigationMenu :items="items" variant="link" color="gray" /> -->
<template #right>
<UButton
aria-label="Nuxt Website"
icon="i-simple-icons-nuxtdotjs"
to="https://nuxt.com"
target="_blank"
color="gray"
variant="ghost"
/>
<UButton
aria-label="Nuxt UI on Discord"
icon="i-simple-icons-discord"
to="https://chat.nuxt.dev"
target="_blank"
color="gray"
variant="ghost"
/>
<UButton
aria-label="Nuxt on X"
icon="i-simple-icons-x"
to="https://x.com/nuxt_js"
target="_blank"
color="gray"
variant="ghost"
/>
<UButton
aria-label="Nuxt UI on GitHub"
icon="i-simple-icons-github"
to="https://github.com/nuxt/ui"
target="_blank"
color="gray"
variant="ghost"
/>
</template>
</UFooter>
</template>

View File

@@ -0,0 +1,55 @@
<script setup lang="ts">
import type { NavItem } from '@nuxt/content'
import type { NavigationMenuItem } from '@nuxt/ui'
const props = defineProps<{
links: NavigationMenuItem[]
}>()
const config = useRuntimeConfig().public
const navigation = inject<Ref<NavItem[]>>('navigation')
const items = computed(() => props.links.map(({ icon, ...link }) => link))
</script>
<template>
<UHeader>
<template #left>
<NuxtLink to="/" class="flex items-end gap-2 font-bold text-xl text-gray-900 dark:text-white" aria-label="Nuxt UI">
<Logo class="w-auto h-6" />
<UBadge :label="`v${config.version}`" variant="subtle" size="sm" class="-mb-[2px] rounded font-semibold" />
</NuxtLink>
</template>
<!-- <UNavigationMenu :items="items" variant="link" /> -->
<template #right>
<ColorPicker />
<UTooltip text="Search" :kbds="['meta', 'K']">
<UContentSearchButton />
</UTooltip>
<!-- <UColorModeButton /> -->
<UButton
color="gray"
variant="ghost"
to="https://github.com/nuxt/ui"
target="_blank"
icon="i-simple-icons-github"
aria-label="GitHub"
/>
</template>
<template #content>
<UNavigationMenu orientation="vertical" :items="items" class="-ml-2.5" />
<USeparator type="dashed" class="my-4" />
<UContentNavigation :navigation="navigation" />
</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(--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="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="var(--color-primary-DEFAULT)" />
</svg>
</template>

View File

@@ -0,0 +1,62 @@
<template>
<UPopover mode="hover" :ui="{ content: 'p-2' }">
<template #default="{ open }">
<UButton
icon="i-heroicons-swatch-20-solid"
color="gray"
:variant="open ? 'soft' : 'ghost'"
square
aria-label="Color picker"
:ui="{ leadingIcon: 'text-primary-500 dark:text-primary-400' }"
/>
</template>
<template #content>
<fieldset class="grid grid-cols-5 gap-px">
<legend class="text-[11px] font-bold mb-1">
Primary
</legend>
<ColorPickerPill v-for="color in primaryColors" :key="color" :color="color" :selected="primary" @select="primary = color" />
</fieldset>
<USeparator class="my-2" type="dashed" />
<fieldset class="grid grid-cols-5 gap-px">
<legend class="text-[11px] font-bold mb-1">
Gray
</legend>
<ColorPickerPill v-for="color in grayColors" :key="color" :color="color" :selected="gray" @select="gray = color" />
</fieldset>
</template>
</UPopover>
</template>
<script setup lang="ts">
const appConfig = useAppConfig()
// Computed
const primaryColors = ['red', 'orange', 'amber', 'yellow', 'lime', 'green', 'emerald', 'teal', 'cyan', 'sky', 'blue', 'indigo', 'violet', 'purple', 'fuchsia', 'pink', 'rose']
const primary = computed({
get() {
return appConfig.ui.colors.primary
},
set(option) {
appConfig.ui.colors.primary = option
window.localStorage.setItem('nuxt-ui-primary', appConfig.ui.colors.primary)
}
})
const grayColors = ['slate', 'cool', 'zinc', 'neutral', 'stone']
const gray = computed({
get() {
return appConfig.ui.colors.gray
},
set(option) {
appConfig.ui.colors.gray = option
window.localStorage.setItem('nuxt-ui-gray', appConfig.ui.colors.gray)
}
})
</script>

View File

@@ -0,0 +1,24 @@
<template>
<UTooltip :text="color" class="capitalize" :portal="false">
<UButton
color="gray"
square
:variant="color === selected ? 'soft' : 'ghost'"
@click.stop.prevent="$emit('select')"
>
<span
class="inline-block w-3 h-3 rounded-full"
:class="`bg-[--color-light] dark:bg-[--color-dark]`"
:style="{
'--color-light': `var(--color-${color}-500)`,
'--color-dark': `var(--color-${color}-400)`
}"
/>
</UButton>
</UTooltip>
</template>
<script setup lang="ts">
defineProps<{ color: string, selected: string }>()
defineEmits(['select'])
</script>

View File

@@ -0,0 +1,265 @@
<!-- eslint-disable no-useless-escape -->
<script setup lang="ts">
import json5 from 'json5'
import { upperFirst, camelCase, kebabCase } from 'scule'
import * as theme from '#build/ui'
import { get, set } from '#ui/utils'
const props = defineProps<{
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 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
}>()
const route = useRoute()
const { $prettier } = useNuxtApp()
const camelName = camelCase(route.params.slug[route.params.slug.length - 1])
const name = `U${upperFirst(camelName)}`
const componentProps = reactive({ ...(props.props || {}) })
function getComponentProp(name: string) {
return get(componentProps, name) || undefined
}
function setComponentProp(name: string, value: any) {
set(componentProps, name, value)
}
const componentTheme = theme[camelName]
const meta = await fetchComponentMeta(name as any)
function mapKeys(obj, parentKey = '') {
return Object.entries(obj || {}).flatMap(([key, value]) => {
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) => {
const prop = meta?.meta?.props?.find((prop: any) => prop.name === key)
const propItems = get(props.items, key, [])
const items = propItems.length
? propItems.map(item => ({
value: item,
label: item
}))
: prop?.type === 'boolean'
? [{ 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
})).filter(variant => key.toLowerCase().endsWith('color') ? !['error'].includes(variant.value) : true)
return {
name: key,
label: key,
type: prop?.type,
items
}
})
})
const code = computed(() => {
let code = ''
if (props.collapse) {
code += `::code-collapse
`
}
code += `\`\`\`vue`
if (props.external?.length) {
code += `
<script setup lang="ts">
`
for (const key of props.external) {
code += `const ${key === 'modelValue' ? 'value' : key} = ref(${json5.stringify(componentProps[key], null, 2).replace(/,([ |\t\n]+[}|\]])/g, '$1')})
`
}
code += `<\/script>
`
}
code += `
<template>
<${name}`
for (const [key, value] of Object.entries(componentProps)) {
if (key === 'modelValue') {
code += ` v-model="value"`
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 += ` ${prop?.type.includes('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}-${JSON.stringify({ 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
})
} 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-gray-300 dark:border-gray-700 border-b-0 relative rounded-t-md 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-gray-300 dark:ring-gray-700 rounded"
:ui="{
wrapper: 'bg-gray-50 dark:bg-gray-800/50 rounded-l flex border-r border-gray-300 dark:border-gray-700',
label: 'text-gray-500 dark:text-gray-400 px-2 py-1.5',
container: 'mt-0'
}"
>
<USelectMenu
v-if="option.items?.length"
:model-value="getComponentProp(option.name)"
:items="option.items"
value-key="value"
color="gray"
variant="soft"
class="rounded rounded-l-none min-w-12"
:search="false"
: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>
</USelectMenu>
<UInput
v-else
:type="option.type?.includes('number') ? 'number' : 'text'"
:model-value="getComponentProp(option.name)"
color="gray"
variant="soft"
:ui="{ base: 'rounded rounded-l-none min-w-12' }"
@update:model-value="setComponentProp(option.name, $event)"
/>
</UFormField>
</template>
</div>
<div class="flex border border-b-0 border-gray-300 dark:border-gray-700 relative p-4 z-[1]" :class="[!options.length && 'rounded-t-md', props.class]">
<component :is="name" v-bind="componentProps" @update:model-value="!!componentProps.modelValue && setComponentProp('modelValue', $event)">
<template v-for="slot in Object.keys(slots || {})" :key="slot" #[slot]>
<ContentSlot :name="slot" unwrap="p">
{{ slots[slot] }}
</ContentSlot>
</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>
<ProseCodeInline>
{{ event.name }}
</ProseCodeInline>
</ProseTd>
<ProseTd>
<HighlightInlineType v-if="event.type" :type="event.type" />
</ProseTd>
</ProseTr>
</ProseTbody>
</ProseTable>
</template>

View File

@@ -0,0 +1,86 @@
<script setup lang="ts">
import { camelCase } from 'scule'
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
}>(), {
preview: true
})
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]`}
${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
})
} catch {
formatted = code.value
}
return parseMarkdown(formatted)
}, { watch: [code] })
</script>
<template>
<div class="my-5">
<div v-if="preview">
<div class="flex border border-b-0 border-gray-300 dark:border-gray-700 relative p-4 rounded-t-md z-[1]" :class="[props.class]">
<component :is="camelName" v-bind="componentProps" />
</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,85 @@
<script setup lang="ts">
import { upperFirst, camelCase } from 'scule'
import type { ComponentMeta } from 'vue-component-meta'
import * as theme from '#build/ui'
const props = defineProps<{
ignore?: string[]
}>()
const route = useRoute()
const camelName = camelCase(route.params.slug[route.params.slug.length - 1])
const name = `U${upperFirst(camelName)}`
const componentTheme = theme[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
}
})
})
</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>
<ProseCodeInline>
{{ prop.name }}
</ProseCodeInline>
</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-gray-600 dark:text-gray-300 mt-1" />
<ComponentPropsSchema v-if="prop.schema" :prop="prop" :ignore="ignore" />
</ProseTd>
</ProseTr>
</ProseTbody>
</ProseTable>
</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']) {
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)
}
const schemaProps = computed(() => {
return getSchemaProps(props.prop.schema).map((prop) => {
const defaultValue = prop.default ?? prop.tags?.find(tag => 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>
<Collapsible 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-gray-500 dark:text-gray-400 my-1" />
</ProseLi>
</ProseUl>
</Collapsible>
</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>
<ProseCodeInline>
{{ slot.name }}
</ProseCodeInline>
</ProseTd>
<ProseTd>
<HighlightInlineType v-if="slot.type" :type="slot.type" />
<MDC v-if="slot.description" :value="slot.description" class="text-gray-600 dark:text-gray-300 mt-1" />
</ProseTd>
</ProseTr>
</ProseTbody>
</ProseTable>
</template>

View File

@@ -0,0 +1,69 @@
<script setup lang="ts">
import json5 from 'json5'
import { camelCase } from 'scule'
import * as theme from '#build/ui'
const route = useRoute()
const name = camelCase(route.params.slug[route.params.slug.length - 1])
const strippedCompoundVariants = ref(false)
function stripCompoundVariants(component) {
if (component.compoundVariants) {
component.compoundVariants = component.compoundVariants.filter((compoundVariant: any) => {
if (compoundVariant.color) {
if (!['primary', 'gray'].includes(compoundVariant.color)) {
strippedCompoundVariants.value = true
return false
}
}
if (compoundVariant.highlightColor) {
if (!['primary', 'gray'].includes(compoundVariant.highlightColor)) {
strippedCompoundVariants.value = true
return false
}
}
return true
})
}
return component
}
const component = computed(() => {
return {
ui: {
[name]: stripCompoundVariants(theme[name])
}
}
})
const { data: ast } = await useAsyncData(`component-theme-${name}`, async () => {
const md = `
::code-collapse
\`\`\`ts [app.config.ts]
export default defineAppConfig(${json5.stringify(component.value, null, 2).replace(/,([ |\t\n]+[}|\])])/g, '$1')})
\`\`\`\
::
${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)
})
</script>
<template>
<MDCRenderer v-if="ast" :body="ast.body" :data="ast.data" />
</template>

View File

@@ -0,0 +1,29 @@
<script setup lang="ts">
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-${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,27 @@
<script setup lang="ts">
import json5 from 'json5'
const appConfig = useAppConfig()
const icons = computed(() => {
return {
ui: {
icons: appConfig.ui.icons
}
}
})
const { data: ast } = await useAsyncData(`icons-theme`, async () => {
const md = `
\`\`\`ts [app.config.ts]
export default defineAppConfig(${json5.stringify(icons.value, null, 2).replace(/,([ |\t\n]+[}|\])])/g, '$1')})
\`\`\`\
`
return parseMarkdown(md)
})
</script>
<template>
<MDCRenderer v-if="ast" :body="ast.body" :data="ast.data" />
</template>

View File

@@ -0,0 +1,24 @@
<script setup lang="ts">
const items = [
{
label: 'Icons',
icon: 'i-heroicons-face-smile'
},
{
label: 'Colors',
icon: 'i-heroicons-swatch'
},
{
label: 'Components',
icon: 'i-heroicons-cube-transparent'
}
]
</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-heroicons-face-smile'
},
{
label: 'Colors',
icon: 'i-heroicons-swatch'
},
{
label: 'Components',
icon: 'i-heroicons-cube-transparent'
}
]
</script>
<template>
<UAccordion :items="items">
<template #content="{ item }">
<p class="pb-3.5 text-sm text-gray-500 dark:text-gray-400">
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-heroicons-face-smile',
content: 'You have nothing to do, @nuxt/icon will handle it automatically.'
},
{
label: 'Colors',
icon: 'i-heroicons-swatch',
slot: 'colors',
content: 'Choose a primary and a gray color from your Tailwind CSS theme.'
},
{
label: 'Components',
icon: 'i-heroicons-cube-transparent',
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-primary-500 dark:text-primary-400">
{{ item.content }}
</p>
</template>
</UAccordion>
</template>

View File

@@ -0,0 +1,32 @@
<script setup lang="ts">
const items = [
{
label: 'Icons',
icon: 'i-heroicons-face-smile',
content: 'You have nothing to do, @nuxt/icon will handle it automatically.'
},
{
label: 'Colors',
icon: 'i-heroicons-swatch',
content: 'Choose a primary and a gray color from your Tailwind CSS theme.'
},
{
label: 'Components',
icon: 'i-heroicons-cube-transparent',
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="green">
<UAvatar
src="https://avatars.githubusercontent.com/u/739984?v=4"
alt="Benjamin Canac"
/>
</UChip>
<UChip inset color="amber">
<UAvatar
src="https://avatars.githubusercontent.com/u/25613751?v=4"
alt="Romain Hamel"
/>
</UChip>
<UChip inset color="red">
<UAvatar
src="https://avatars.githubusercontent.com/u/19751938?v=4"
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-primary-500 dark:hover:ring-primary-400 transition"
raw
>
<UAvatar
src="https://avatars.githubusercontent.com/u/739984?v=4"
alt="Benjamin Canac"
/>
</ULink>
<ULink
to="https://github.com/romhml"
target="_blank"
class="hover:ring-primary-500 dark:hover:ring-primary-400 transition"
raw
>
<UAvatar
src="https://avatars.githubusercontent.com/u/25613751?v=4"
alt="Romain Hamel"
/>
</ULink>
<ULink
to="https://github.com/noook"
target="_blank"
class="hover:ring-primary-500 dark:hover:ring-primary-400 transition"
raw
>
<UAvatar
src="https://avatars.githubusercontent.com/u/19751938?v=4"
alt="Neil Richter"
/>
</ULink>
</UAvatarGroup>
</template>

View File

@@ -0,0 +1,24 @@
<template>
<UAvatarGroup>
<UTooltip text="benjamincanac">
<UAvatar
src="https://avatars.githubusercontent.com/u/739984?v=4"
alt="Benjamin Canac"
/>
</UTooltip>
<UTooltip text="romhml">
<UAvatar
src="https://avatars.githubusercontent.com/u/25613751?v=4"
alt="Romain Hamel"
/>
</UTooltip>
<UTooltip text="noook">
<UAvatar
src="https://avatars.githubusercontent.com/u/19751938?v=4"
alt="Neil Richter"
/>
</UTooltip>
</UAvatarGroup>
</template>

View File

@@ -0,0 +1,8 @@
<template>
<UChip inset>
<UAvatar
src="https://avatars.githubusercontent.com/u/739984?v=4"
alt="Benjamin Canac"
/>
</UChip>
</template>

View File

@@ -0,0 +1,8 @@
<template>
<UTooltip text="Benjamin Canac">
<UAvatar
src="https://avatars.githubusercontent.com/u/739984?v=4"
alt="Benjamin Canac"
/>
</UTooltip>
</template>

View File

@@ -0,0 +1,32 @@
<script setup lang="ts">
const items = [{
label: 'Home',
to: '/'
}, {
slot: 'dropdown',
icon: 'i-heroicons-ellipsis-horizontal',
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="gray" 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-gray-500 dark:text-gray-400">/</span>
</template>
</UBreadcrumb>
</template>

View File

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

View File

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

View File

@@ -0,0 +1,26 @@
<script setup lang="ts">
const statuses = ['online', 'away', 'busy', 'offline']
const status = ref(statuses[0])
const color = computed(() => ({
online: 'green',
away: 'amber',
busy: 'red',
offline: 'gray'
})[status.value] as any)
const show = computed(() => status.value !== 'offline')
// Note: This is for demonstration purposes only. Don't do this at home.
onMounted(() => {
setInterval(() => {
status.value = statuses[(statuses.indexOf(status.value) + 1) % statuses.length]
}, 1000)
})
</script>
<template>
<UChip :color="color" :show="show" inset>
<UAvatar src="https://avatars.githubusercontent.com/u/739984?v=4" />
</UChip>
</template>

View File

@@ -0,0 +1,19 @@
<template>
<UCollapsible class="w-48">
<UButton
class="group"
label="Open"
color="gray"
variant="subtle"
trailing-icon="i-heroicons-chevron-down-20-solid"
:ui="{
trailingIcon: 'group-data-[state=open]:rotate-180 transition-transform duration-200'
}"
block
/>
<template #content>
<Placeholder class="h-48" />
</template>
</UCollapsible>
</template>

View File

@@ -0,0 +1,23 @@
<script setup lang="ts">
const open = ref(true)
defineShortcuts({
o: () => open.value = !open.value
})
</script>
<template>
<UCollapsible v-model:open="open" class="w-48">
<UButton
label="Open"
color="gray"
variant="subtle"
trailing-icon="i-heroicons-chevron-down-20-solid"
block
/>
<template #content>
<Placeholder class="h-48" />
</template>
</UCollapsible>
</template>

View File

@@ -0,0 +1,28 @@
<script setup lang="ts">
const loading = ref(true)
const items = [{
label: 'Refresh the Page',
slot: 'refresh'
}, {
label: 'Clear Cookies and Refresh'
}, {
label: 'Clear Cache and Refresh'
}]
</script>
<template>
<UContextMenu :items="items" class="w-48">
<div class="flex items-center justify-center rounded-md border border-dashed border-gray-300 dark:border-gray-700 text-sm aspect-video w-72">
Right click here
</div>
<template #refresh-label>
{{ loading ? 'Refreshing...' : 'Refresh the Page' }}
</template>
<template #refresh-trailing>
<UIcon v-if="loading" name="i-heroicons-arrow-path-20-solid" class="shrink-0 size-5 text-primary-500 dark:text-primary-400 animate-spin" />
</template>
</UContextMenu>
</template>

View File

@@ -0,0 +1,34 @@
<script setup lang="ts">
const searchTerm = ref('')
const { data: users, status } = await useFetch('https://jsonplaceholder.typicode.com/users', {
params: { q: searchTerm },
transform: (data: any[]) => {
return data?.map(user => ({ id: user.id, label: user.name, suffix: user.email, avatar: { src: `https://i.pravatar.cc/120?img=${user.id}` } })) || []
},
lazy: true
})
const groups = computed(() => [{
id: 'users',
label: searchTerm.value ? `Users matching “${searchTerm.value}”...` : 'Users',
items: users.value || [],
filter: false
}])
</script>
<template>
<UDrawer>
<UButton label="Search users..." color="gray" variant="subtle" icon="i-heroicons-magnifying-glass" />
<template #content>
<UCommandPalette
v-model:search-term="searchTerm"
:loading="status === 'pending'"
:groups="groups"
placeholder="Search users..."
class="h-96 border-t border-gray-200 dark:border-gray-800"
/>
</template>
</UDrawer>
</template>

View File

@@ -0,0 +1,18 @@
<script setup lang="ts">
const open = ref(false)
</script>
<template>
<UDrawer v-model:open="open" title="Drawer with footer" description="This is useful when you want a form in a Drawer.">
<UButton label="Open" color="gray" variant="subtle" trailing-icon="i-heroicons-chevron-up-20-solid" />
<template #body>
<Placeholder class="h-48" />
</template>
<template #footer>
<UButton label="Submit" color="gray" class="justify-center" />
<UButton label="Cancel" color="gray" variant="outline" class="justify-center" @click="open = false" />
</template>
</UDrawer>
</template>

View File

@@ -0,0 +1,17 @@
<script setup lang="ts">
const open = ref(false)
defineShortcuts({
o: () => open.value = !open.value
})
</script>
<template>
<UDrawer v-model:open="open">
<UButton label="Open" color="gray" variant="subtle" trailing-icon="i-heroicons-chevron-up-20-solid" />
<template #content>
<Placeholder class="h-48 m-4" />
</template>
</UDrawer>
</template>

View File

@@ -0,0 +1,23 @@
<script setup lang="ts">
const items = [{
label: 'Profile',
icon: 'i-heroicons-user',
slot: 'profile'
}, {
label: 'Billing',
icon: 'i-heroicons-credit-card'
}, {
label: 'Settings',
icon: 'i-heroicons-cog'
}]
</script>
<template>
<UDropdownMenu :items="items" class="w-48">
<UButton label="Open" color="gray" variant="outline" icon="i-heroicons-bars-3" />
<template #profile-trailing>
<UIcon name="i-heroicons-check-badge" class="shrink-0 size-5 text-primary-500 dark:text-primary-400" />
</template>
</UDropdownMenu>
</template>

View File

@@ -0,0 +1,24 @@
<script setup lang="ts">
const open = ref(false)
defineShortcuts({
o: () => open.value = !open.value
})
const items = [{
label: 'Profile',
icon: 'i-heroicons-user'
}, {
label: 'Billing',
icon: 'i-heroicons-credit-card'
}, {
label: 'Settings',
icon: 'i-heroicons-cog'
}]
</script>
<template>
<UDropdownMenu v-model:open="open" :items="items" class="w-48">
<UButton label="Open" color="gray" variant="outline" icon="i-heroicons-bars-3" />
</UDropdownMenu>
</template>

View File

@@ -0,0 +1,34 @@
<script setup lang="ts">
const searchTerm = ref('')
const { data: users, status } = await useFetch('https://jsonplaceholder.typicode.com/users', {
params: { q: searchTerm },
transform: (data: any[]) => {
return data?.map(user => ({ id: user.id, label: user.name, suffix: user.email, avatar: { src: `https://i.pravatar.cc/120?img=${user.id}` } })) || []
},
lazy: true
})
const groups = computed(() => [{
id: 'users',
label: searchTerm.value ? `Users matching “${searchTerm.value}”...` : 'Users',
items: users.value || [],
filter: false
}])
</script>
<template>
<UModal>
<UButton label="Search users..." color="gray" variant="subtle" icon="i-heroicons-magnifying-glass" />
<template #content>
<UCommandPalette
v-model:search-term="searchTerm"
:loading="status === 'pending'"
:groups="groups"
placeholder="Search users..."
class="h-96"
/>
</template>
</UModal>
</template>

View File

@@ -0,0 +1,15 @@
<script setup lang="ts">
const modal = useModal()
defineProps<{
count: number
}>()
</script>
<template>
<UModal :title="`This modal was opened programmatically ${count} times`">
<template #footer>
<UButton color="gray" label="Close" @click="modal.close()" />
</template>
</UModal>
</template>

View File

@@ -0,0 +1,18 @@
<script setup lang="ts">
const open = ref(false)
</script>
<template>
<UModal v-model:open="open" title="Modal with footer" description="This is useful when you want a form in a Modal." :ui="{ footer: 'justify-end' }">
<UButton label="Open" color="gray" variant="subtle" />
<template #body>
<Placeholder class="h-48" />
</template>
<template #footer>
<UButton label="Cancel" color="gray" variant="outline" @click="open = false" />
<UButton label="Submit" color="gray" />
</template>
</UModal>
</template>

View File

@@ -0,0 +1,22 @@
<script setup lang="ts">
const first = ref(false)
const second = ref(false)
</script>
<template>
<UModal v-model:open="first" title="First modal" :ui="{ footer: 'justify-end' }">
<UButton color="gray" variant="subtle" label="Open" />
<template #footer>
<UButton label="Close" color="gray" variant="outline" @click="first = false" />
<UModal v-model:open="second" title="Second modal" :ui="{ footer: 'justify-end' }">
<UButton label="Open second" color="gray" />
<template #footer>
<UButton label="Close" color="gray" variant="outline" @click="second = false" />
</template>
</UModal>
</template>
</UModal>
</template>

View File

@@ -0,0 +1,17 @@
<script setup lang="ts">
const open = ref(false)
defineShortcuts({
o: () => open.value = !open.value
})
</script>
<template>
<UModal v-model:open="open">
<UButton label="Open" color="gray" variant="subtle" />
<template #content>
<Placeholder class="h-48 m-4" />
</template>
</UModal>
</template>

View File

@@ -0,0 +1,20 @@
<script setup lang="ts">
import { LazyModalExample } from '#components'
const count = ref(0)
const modal = useModal()
function open() {
count.value++
modal.open(LazyModalExample, {
description: 'And you can even provide a description!',
count: count.value
})
}
</script>
<template>
<UButton label="Open" color="gray" variant="subtle" @click="open" />
</template>

View File

@@ -0,0 +1,27 @@
<script setup lang="ts">
const items = [
{
label: 'Guide',
icon: 'i-heroicons-book-open'
},
{
label: 'Composables',
icon: 'i-heroicons-circle-stack'
},
{
label: 'Components',
icon: 'i-heroicons-cube-transparent',
slot: 'components'
}
]
</script>
<template>
<UNavigationMenu :items="items" class="justify-center">
<template #components-trailing>
<UBadge label="44" variant="subtle" size="sm" />
</template>
</UNavigationMenu>
</template>

View File

@@ -0,0 +1,110 @@
<script setup lang="ts">
const items = [
{
label: 'Guide',
icon: 'i-heroicons-book-open',
children: [
{
label: 'Introduction',
description: 'Fully styled and customizable components for Nuxt.',
icon: 'i-heroicons-home'
},
{
label: 'Installation',
description: 'Learn how to install and configure Nuxt UI in your application.',
icon: 'i-heroicons-cloud-arrow-down'
},
{
label: 'Icons',
icon: 'i-heroicons-face-smile',
description: 'You have nothing to do, @nuxt/icon will handle it automatically.'
},
{
label: 'Colors',
icon: 'i-heroicons-swatch',
description: 'Choose a primary and a gray color from your Tailwind CSS theme.'
},
{
label: 'Theme',
icon: 'i-heroicons-cog',
description: 'You can customize components by using the `class` / `ui` props or in your app.config.ts.'
}
]
},
{
label: 'Composables',
icon: 'i-heroicons-circle-stack',
children: [
{
label: 'defineShortcuts',
icon: 'i-heroicons-document-text-20-solid',
description: 'Define shortcuts for your application.'
},
{
label: 'useModal',
icon: 'i-heroicons-document-text-20-solid',
description: 'Display a modal within your application.'
},
{
label: 'useSlideover',
icon: 'i-heroicons-document-text-20-solid',
description: 'Display a slideover within your application.'
},
{
label: 'useToast',
icon: 'i-heroicons-document-text-20-solid',
description: 'Display a toast within your application.'
}
]
},
{
label: 'Components',
icon: 'i-heroicons-cube-transparent',
children: [
{
label: 'Link',
icon: 'i-heroicons-document-text-20-solid',
description: 'Use NuxtLink with superpowers.'
},
{
label: 'Modal',
icon: 'i-heroicons-document-text-20-solid',
description: 'Display a modal within your application.'
},
{
label: 'NavigationMenu',
icon: 'i-heroicons-document-text-20-solid',
description: 'Display a list of links.'
},
{
label: 'Pagination',
icon: 'i-heroicons-document-text-20-solid',
description: 'Display a list of pages.'
},
{
label: 'Popover',
icon: 'i-heroicons-document-text-20-solid',
description: 'Display a non-modal dialog that floats around a trigger element.'
},
{
label: 'Progress',
icon: 'i-heroicons-document-text-20-solid',
description: 'Show a horizontal bar to indicate task progression.'
}
]
}
]
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>
<UNavigationMenu v-model="active" :items="items" class="justify-center" />
</template>

View File

@@ -0,0 +1,17 @@
<script setup lang="ts">
const open = ref(false)
defineShortcuts({
o: () => open.value = !open.value
})
</script>
<template>
<UPopover v-model:open="open">
<UButton label="Open" color="gray" variant="subtle" />
<template #content>
<Placeholder class="size-48 m-4 inline-flex" />
</template>
</UPopover>
</template>

View File

@@ -0,0 +1,35 @@
<script setup lang="ts">
const { data: users, status } = await useFetch('https://jsonplaceholder.typicode.com/users', {
transform: (data: { name: string, id: number }[]) => {
return data?.map(user => ({
label: user.name,
value: String(user.id),
avatar: { src: `https://i.pravatar.cc/120?img=${user.id}` }
})) || []
},
lazy: true
})
function getUserAvatar(value: string) {
return users.value?.find(user => user.value === value)?.avatar || {}
}
</script>
<template>
<USelect
:items="users || []"
:loading="status === 'pending'"
icon="i-heroicons-user"
placeholder="Select user"
class="w-48"
>
<template #leading="{ modelValue, ui }">
<UAvatar
v-if="modelValue"
v-bind="getUserAvatar(modelValue)"
:size="ui.itemLeadingAvatarSize()"
:class="ui.itemLeadingAvatar()"
/>
</template>
</USelect>
</template>

View File

@@ -0,0 +1,13 @@
<script setup lang="ts">
const items = ref(['Backlog', 'Todo', 'In Progress', 'Done'])
</script>
<template>
<USelect
default-value="Backlog"
:items="items"
:ui="{
trailingIcon: 'group-data-[state=open]:rotate-180 transition-transform duration-200'
}"
/>
</template>

View File

@@ -0,0 +1,45 @@
<script setup lang="ts">
const items = ref([
{
label: 'benjamincanac',
value: 'benjamincanac',
avatar: {
src: 'https://github.com/benjamincanac.png',
alt: 'benjamincanac'
}
},
{
label: 'romhml',
value: 'romhml',
avatar: {
src: 'https://github.com/romhml.png',
alt: 'romhml'
}
},
{
label: 'noook',
value: 'noook',
avatar: {
src: 'https://github.com/noook.png',
alt: 'noook'
}
}
])
function getAvatar(value: string) {
return items.value.find(item => item.value === value)?.avatar
}
</script>
<template>
<USelect default-value="benjamincanac" :items="items" class="w-40">
<template #leading="{ modelValue, ui }">
<UAvatar
v-if="modelValue"
v-bind="getAvatar(modelValue)"
:size="ui.itemLeadingAvatarSize()"
:class="ui.itemLeadingAvatar()"
/>
</template>
</USelect>
</template>

View File

@@ -0,0 +1,44 @@
<script setup lang="ts">
const items = ref([
{
label: 'bug',
value: 'bug',
chip: {
color: 'red' as const
}
},
{
label: 'enhancement',
value: 'enhancement',
chip: {
color: 'blue' as const
}
},
{
label: 'feature',
value: 'feature',
chip: {
color: 'violet' as const
}
}
])
function getChip(value: string) {
return items.value.find(item => item.value === value)?.chip
}
</script>
<template>
<USelect default-value="bug" :items="items" class="w-40">
<template #leading="{ modelValue, ui }">
<UChip
v-if="modelValue"
v-bind="getChip(modelValue)"
inset
standalone
:size="ui.itemLeadingChipSize()"
:class="ui.itemLeadingChip()"
/>
</template>
</USelect>
</template>

View File

@@ -0,0 +1,31 @@
<script setup lang="ts">
const selected = ref('backlog')
const items = ref([
{
label: 'Backlog',
value: 'backlog',
icon: 'i-heroicons-question-mark-circle'
},
{
label: 'Todo',
value: 'todo',
icon: 'i-heroicons-plus-circle'
},
{
label: 'In Progress',
value: 'in_progress',
icon: 'i-heroicons-arrow-up-circle'
},
{
label: 'Done',
value: 'done',
icon: 'i-heroicons-check-circle'
}
])
const icon = computed(() => items.value.find(item => item.value === selected.value)?.icon)
</script>
<template>
<USelect v-model="selected" :icon="icon" :items="items" class="w-40" />
</template>

View File

@@ -0,0 +1,12 @@
<script setup lang="ts">
const open = ref(false)
const items = ref(['Backlog', 'Todo', 'In Progress', 'Done'])
defineShortcuts({
o: () => open.value = !open.value
})
</script>
<template>
<USelect v-model:open="open" default-value="Backlog" :items="items" />
</template>

View File

@@ -0,0 +1,10 @@
<template>
<div class="flex items-center gap-4">
<USkeleton class="h-12 w-12 rounded-full" />
<div class="grid gap-2">
<USkeleton class="h-4 w-[250px]" />
<USkeleton class="h-4 w-[200px]" />
</div>
</div>
</template>

View File

@@ -0,0 +1,19 @@
<script setup lang="ts">
const slideover = useSlideover()
defineProps<{
count: number
}>()
</script>
<template>
<USlideover :description="`This slideover was opened programmatically ${count} times`">
<template #body>
<Placeholder class="h-full" />
</template>
<template #footer>
<UButton color="gray" label="Close" @click="slideover.close()" />
</template>
</USlideover>
</template>

View File

@@ -0,0 +1,18 @@
<script setup lang="ts">
const open = ref(false)
</script>
<template>
<USlideover v-model:open="open" title="Slideover with footer" description="This is useful when you want a form in a Slideover." :ui="{ footer: 'justify-end' }">
<UButton label="Open" color="gray" variant="subtle" />
<template #body>
<Placeholder class="h-full" />
</template>
<template #footer>
<UButton label="Cancel" color="gray" variant="outline" @click="open = false" />
<UButton label="Submit" color="gray" />
</template>
</USlideover>
</template>

View File

@@ -0,0 +1,30 @@
<script setup lang="ts">
const first = ref(false)
const second = ref(false)
</script>
<template>
<USlideover v-model:open="first" title="First slideover" :ui="{ footer: 'justify-end' }">
<UButton color="gray" variant="subtle" label="Open" />
<template #body>
<Placeholder class="h-full" />
</template>
<template #footer>
<UButton label="Close" color="gray" variant="outline" @click="first = false" />
<USlideover v-model:open="second" title="Second slideover" :ui="{ footer: 'justify-end' }">
<UButton label="Open second" color="gray" />
<template #body>
<Placeholder class="h-full" />
</template>
<template #footer>
<UButton label="Close" color="gray" variant="outline" @click="second = false" />
</template>
</USlideover>
</template>
</USlideover>
</template>

View File

@@ -0,0 +1,17 @@
<script setup lang="ts">
const open = ref(false)
defineShortcuts({
o: () => open.value = !open.value
})
</script>
<template>
<USlideover v-model:open="open">
<UButton label="Open" color="gray" variant="subtle" />
<template #content>
<Placeholder class="h-full m-4" />
</template>
</USlideover>
</template>

View File

@@ -0,0 +1,20 @@
<script setup lang="ts">
import { LazySlideoverExample } from '#components'
const count = ref(0)
const slideover = useSlideover()
function open() {
count.value++
slideover.open(LazySlideoverExample, {
title: 'Slideover',
count: count.value
})
}
</script>
<template>
<UButton label="Open" color="gray" variant="subtle" @click="open" />
</template>

View File

@@ -0,0 +1,20 @@
<script setup lang="ts">
const items = [
{
label: 'Account',
icon: 'i-heroicons-user'
},
{
label: 'Password',
icon: 'i-heroicons-lock-closed'
}
]
</script>
<template>
<UTabs :items="items" class="w-full">
<template #content="{ item }">
<p>This is the {{ item.label }} tab.</p>
</template>
</UTabs>
</template>

View File

@@ -0,0 +1,65 @@
<script setup lang="ts">
const items = [
{
label: 'Account',
description: 'Make changes to your account here. Click save when you\'re done.',
icon: 'i-heroicons-user',
slot: 'account'
},
{
label: 'Password',
description: 'Change your password here. After saving, you\'ll be logged out.',
icon: 'i-heroicons-lock-closed',
slot: 'password'
}
]
const state = reactive({
name: 'Benjamin Canac',
username: 'benjamincanac',
currentPassword: '',
newPassword: '',
confirmPassword: ''
})
</script>
<template>
<UTabs :items="items" variant="link" class="gap-4 w-full" :ui="{ trigger: 'flex-1' }">
<template #account="{ item }">
<p class="text-gray-500 dark:text-gray-400 mb-4">
{{ item.description }}
</p>
<UForm :state="state" class="flex flex-col gap-4">
<UFormField label="Name" name="name">
<UInput v-model="state.name" class="w-full" />
</UFormField>
<UFormField label="Username" name="username">
<UInput v-model="state.username" class="w-full" />
</UFormField>
<UButton label="Save changes" type="submit" variant="soft" class="self-end" />
</UForm>
</template>
<template #password="{ item }">
<p class="text-gray-500 dark:text-gray-400 mb-4">
{{ item.description }}
</p>
<UForm :state="state" class="flex flex-col gap-4">
<UFormField label="Current Password" name="current" required>
<UInput v-model="state.currentPassword" type="password" required class="w-full" />
</UFormField>
<UFormField label="New Password" name="new" required>
<UInput v-model="state.newPassword" type="password" required class="w-full" />
</UFormField>
<UFormField label="Confirm Password" name="confirm" required>
<UInput v-model="state.confirmPassword" type="password" required class="w-full" />
</UFormField>
<UButton label="Change password" type="submit" variant="soft" class="self-end" />
</UForm>
</template>
</UTabs>
</template>

View File

@@ -0,0 +1,23 @@
<script setup lang="ts">
const items = [
{
label: 'Account'
},
{
label: 'Password'
}
]
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>
<UTabs v-model="active" :content="false" :items="items" class="w-full" />
</template>

View File

@@ -0,0 +1,13 @@
<script setup lang="ts">
const open = ref(false)
defineShortcuts({
o: () => open.value = !open.value
})
</script>
<template>
<UTooltip v-model:open="open" text="Open on GitHub">
<UButton label="Open" color="gray" variant="subtle" />
</UTooltip>
</template>

View File

@@ -1,4 +1,4 @@
<script lang="ts" setup>
<script setup lang="ts">
defineOptions({
inheritAttrs: false
})

View File

@@ -0,0 +1,32 @@
const useComponentExampleState = () => useState('component-example-state', () => ({}))
export async function fetchComponentExample(name: string) {
const state = useComponentExampleState()
if (state.value[name]?.then) {
await state.value[name]
return state.value[name]
}
if (state.value[name]) {
return state.value[name]
}
// Add to nitro prerender
if (import.meta.server) {
const event = useRequestEvent()
event.node.res.setHeader(
'x-nitro-prerender',
[event.node.res.getHeader('x-nitro-prerender'), `/api/component-example/${name}.json`].filter(Boolean).join(',')
)
}
// Store promise to avoid multiple calls
state.value[name] = $fetch(`/api/component-example/${name}.json`).then((data) => {
state.value[name] = data
}).catch(() => {
state.value[name] = {}
})
await state.value[name]
return state.value[name]
}

View File

@@ -1,17 +1,19 @@
const useComponentsMetaState = () => useState('components-meta', () => ({}))
import type { ComponentMeta } from 'vue-component-meta'
export async function fetchComponentMeta (name: string) {
const useComponentsMetaState = () => useState('component-meta-state', () => ({}))
export async function fetchComponentMeta(name: string): Promise<{ meta: ComponentMeta }> {
const state = useComponentsMetaState()
if (state.value[name]?.then) {
await state.value[name]
return state.value[name]
}
if (state.value[name]) { return state.value[name] }
if (state.value[name]) {
return state.value[name]
}
// Store promise to avoid multiple calls
// add to nitro prerender
// Add to nitro prerender
if (import.meta.server) {
const event = useRequestEvent()
event.node.res.setHeader(
@@ -19,8 +21,12 @@ export async function fetchComponentMeta (name: string) {
[event.node.res.getHeader('x-nitro-prerender'), `/api/component-meta/${name}.json`].filter(Boolean).join(',')
)
}
// Store promise to avoid multiple calls
state.value[name] = $fetch(`/api/component-meta/${name}.json`).then((meta) => {
state.value[name] = meta
}).catch(() => {
state.value[name] = {}
})
await state.value[name]

94
docs/app/error.vue Normal file
View File

@@ -0,0 +1,94 @@
<script setup lang="ts">
import type { NuxtError } from '#app'
import type { ContentSearchFile } from '@nuxt/ui-pro'
useSeoMeta({
title: 'Page not found',
description: 'We are sorry but this page could not be found.'
})
defineProps<{
error: NuxtError
}>()
const route = useRoute()
// const colorMode = useColorMode()
// const { branch } = useContentSource()
const runtimeConfig = useRuntimeConfig()
const { integrity, api } = runtimeConfig.public.content
const { data: navigation } = await useAsyncData('navigation', () => fetchContentNavigation(), { default: () => [] })
const { data: files } = await useLazyFetch<ContentSearchFile[]>(`${api.baseURL}/search${integrity ? '.' + integrity : ''}`, { default: () => [] })
// Computed
// const color = computed(() => colorMode.value === 'dark' ? '#18181b' : 'white')
const links = computed(() => {
return [{
label: 'Docs',
icon: 'i-heroicons-book-open',
to: '/getting-started',
active: 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-credit-card',
to: '/pro/pricing'
}, {
label: 'Templates',
icon: 'i-heroicons-computer-desktop',
to: '/pro/templates'
}]
: []), {
label: 'Releases',
icon: 'i-heroicons-rocket-launch',
to: '/releases'
}].filter(Boolean)
})
// 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' }
],
htmlAttrs: {
lang: 'en'
}
})
// Provide
provide('navigation', navigation)
provide('files', files)
</script>
<template>
<UApp>
<NuxtLoadingIndicator />
<Header :links="links" />
<UContainer>
<UMain>
<UPage>
<!-- <UPageError :error="error" /> -->
</UPage>
</UMain>
</UContainer>
<Footer />
<LazyUContentSearch :files="files" :navigation="navigation" :fuse="{ resultLimit: 42 }" />
</UApp>
</template>

View File

@@ -1,13 +1,19 @@
<script setup lang="ts">
import type { NavItem } from '@nuxt/content'
const nav = inject<Ref<NavItem[]>>('navigation')
const navigation = computed(() => nav.value.filter(item => !item._path.startsWith('/pro')))
</script>
<template>
<UMain>
<UContainer>
<UPage>
<template #left>
<UAside>
<BranchSelect />
<UNavigationTree :links="mapContentNavigation(navigation)" />
</UAside>
<UPageAside>
<UContentNavigation :navigation="navigation" highlight />
</UPageAside>
</template>
<slot />
@@ -15,11 +21,3 @@
</UContainer>
</UMain>
</template>
<script setup lang="ts">
import type { NavItem } from '@nuxt/content/dist/runtime/types'
const nav = inject<Ref<NavItem[]>>('navigation')
const navigation = computed(() => nav.value.filter(item => !item._path.startsWith('/pro')))
</script>

View File

@@ -0,0 +1,111 @@
<script setup lang="ts">
import { withoutTrailingSlash } from 'ufo'
import { findPageHeadline } from '#ui-pro/utils/content'
const route = useRoute()
definePageMeta({
layout: 'docs'
})
const { data: page } = await useAsyncData(route.path, () => queryContent(route.path).findOne())
if (!page.value) {
throw createError({ statusCode: 404, statusMessage: 'Page not found', fatal: true })
}
const { data: surround } = await useAsyncData(`${route.path}-surround`, () => {
return queryContent()
.where({
_extension: 'md',
navigation: {
$ne: false
}
})
.only(['title', 'description', '_path'])
.findSurround(withoutTrailingSlash(route.path))
}, { default: () => [] })
const headline = computed(() => findPageHeadline(page.value))
useSeoMeta({
titleTemplate: '%s - Nuxt UI',
title: page.value.title,
ogTitle: `${page.value.title} - Nuxt UI`,
description: page.value.description,
ogDescription: page.value.description
})
defineOgImageComponent('Docs', {
headline: headline.value
})
// const communityLinks = computed(() => [{
// icon: 'i-heroicons-pencil-square',
// label: 'Edit this page',
// to: `https://github.com/nuxt/ui/edit/dev/docs/content/${page?.value?._file}`,
// target: '_blank'
// }, {
// icon: 'i-heroicons-star',
// label: 'Star on GitHub',
// to: 'https://github.com/nuxt/ui',
// target: '_blank'
// }, {
// icon: 'i-heroicons-lifebuoy',
// label: 'Contributing',
// to: '/getting-started/contributing'
// }, {
// label: 'Roadmap',
// icon: 'i-heroicons-map',
// to: '/roadmap'
// }])
// const resourcesLinks = [{
// icon: 'i-simple-icons-figma',
// label: 'Figma Kit',
// to: 'https://www.figma.com/community/file/1288455405058138934',
// target: '_blank'
// }, {
// label: 'Playground',
// icon: 'i-simple-icons-stackblitz',
// to: 'https://stackblitz.com/edit/nuxt-ui',
// target: '_blank'
// }, {
// icon: 'i-simple-icons-nuxtdotjs',
// label: 'Nuxt docs',
// to: 'https://nuxt.com',
// target: '_blank'
// }]
</script>
<template>
<UPage v-if="page">
<UPageHeader :title="page.title" :description="page.description" :links="page.links" :headline="headline" />
<UPageBody>
<ContentRenderer v-if="page.body" :value="page" />
<USeparator />
<UContentSurround :surround="surround" />
</UPageBody>
<template v-if="page?.body?.toc?.links?.length" #right>
<UContentToc :links="page.body.toc.links">
<!-- <template #bottom>
<USeparator v-if="page.body?.toc?.links?.length" type="dashed" />
<UPageLinks title="Community" :links="communityLinks" />
<USeparator type="dashed" />
<UPageLinks title="Resources" :links="resourcesLinks" />
<USeparator type="dashed" />
<AdsPro />
<AdsCarbon />
</template> -->
</UContentToc>
</template>
</UPage>
</template>

View File

@@ -1,11 +1,11 @@
<template>
<div class="p-4 flex flex-col justify-center h-screen overflow-auto">
<component :is="name" />
</div>
</template>
<script setup lang="ts">
const route = useRoute()
const name = route.params.slug[0]
</script>
<template>
<div class="p-4 flex flex-col justify-center h-screen overflow-auto">
<component :is="name" />
</div>
</template>

View File

@@ -0,0 +1,38 @@
export default defineNuxtPlugin({
enforce: 'post',
setup() {
const appConfig = useAppConfig()
if (import.meta.client) {
if (window.localStorage.getItem('nuxt-ui-primary')) {
appConfig.ui.colors.primary = window.localStorage.getItem('nuxt-ui-primary')
}
if (window.localStorage.getItem('nuxt-ui-gray')) {
appConfig.ui.colors.gray = window.localStorage.getItem('nuxt-ui-gray')
}
}
if (import.meta.server) {
useHead({
script: [
{
innerHTML: `
let html = document.querySelector('style#nuxt-ui-colors').innerHTML;
if (localStorage.getItem('nuxt-ui-primary')) {
html = html.replaceAll('${appConfig.ui.colors.primary}', localStorage.getItem('nuxt-ui-primary'))
}
if (localStorage.getItem('nuxt-ui-gray')) {
html = html.replaceAll('${appConfig.ui.colors.gray}', localStorage.getItem('nuxt-ui-gray'))
}
document.querySelector('style#nuxt-ui-colors').innerHTML = html
`.replace(/\s+/g, ' '),
type: 'text/javascript',
tagPriority: -1
}
]
})
}
}
})

View File

@@ -1,11 +1,12 @@
import type { Options } from 'prettier'
import { defu } from 'defu'
import PrettierWorker from '@/workers/prettier.js?worker&inline'
export interface SimplePrettier {
format: (source: string, options?: Options) => Promise<string>;
format: (source: string, options?: Options) => Promise<string>
}
function createPrettierWorkerApi (worker: Worker): SimplePrettier {
function createPrettierWorkerApi(worker: Worker): SimplePrettier {
let counter = 0
const handlers = {}
@@ -17,6 +18,7 @@ function createPrettierWorkerApi (worker: Worker): SimplePrettier {
}
const [resolve, reject] = handlers[uid]
// eslint-disable-next-line @typescript-eslint/no-dynamic-delete
delete handlers[uid]
if (error) {
@@ -26,7 +28,7 @@ function createPrettierWorkerApi (worker: Worker): SimplePrettier {
}
})
function postMessage<T> (message) {
function postMessage<T>(message) {
const uid = ++counter
return new Promise<T>((resolve, reject) => {
handlers[uid] = [resolve, reject]
@@ -35,22 +37,22 @@ function createPrettierWorkerApi (worker: Worker): SimplePrettier {
}
return {
format (source: string, options?: Options) {
format(source: string, options?: Options) {
return postMessage({ type: 'format', source, options })
}
}
}
export default defineNuxtPlugin({
async setup () {
async setup() {
let prettier: SimplePrettier
if (import.meta.server) {
const prettierModule = await import('prettier')
prettier = {
format (source, options = {
parser: 'markdown'
}) {
return prettierModule.format(source, options)
format(source, options = {}) {
return prettierModule.format(source, defu(options, {
parser: 'markdown'
}))
}
}
} else {

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