-
Notifications
You must be signed in to change notification settings - Fork 584
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
v3 #1289
Comments
I would like to help, if I'm able to. Is there going to be a dedicated branch or will it be done in the |
Once we start this, there will be indeed a new branch with auto-release so we can try it out and especially keep working on the |
I have few design ideas if you are open to this I would like to share it for the future of Nuxt UI 3. Should we discuss this in this issue or it'll be better to discuss design ideas in seperate discussion thread? |
@jd-solanki You can share them here! |
Since it is supposed to be a refactoring to all components, could we give the possibility of compatibility with unocss? |
@sawa-ko It will be made with Tailwind v4. To what end would you make it compatible with Uno? |
I've started working on this in a private repository of mine, I'll open-source it once I'm satisfied with the base so you guys can check it out 😊. A lot has changed since I'll post regular updates on this issue. |
Please tell me how long it will take for this upgrade to be available. |
I have no idea how long it will take and it's not entirely up to us, I hope to release it at the same time as the official release of Tailwind v4. |
That's awesome. The new version of nuxt-ui uses exactly the tech stack I expected. I tried to build my own UI library using radix-ui and tailwind-variants, but I immediately found that even with radix-ui, it is not easy to build a full UI library. But I got an idea with an API that works with any design language. If you are interested, here is my demo repository: |
@robin-dongbin It's already in the making. There are already 13 components done, 36 more to go 😅 |
Since the component library is based on radix-ui without styles, I thought it would be nice to provide an api that is abstracted from various design systems, so you can switch styles from one system to another at any time. If people want to implement another design system, they can just customize it, share files, or even contribute to a repository. Taking things a step further, it is possible to switch between different design systems at runtime. Of course, I'm just offering an idea, and if you think it's too late, that's fine |
This is actually already what we're doing with the App Config. You can customize the classes for every part of every component. |
Thanks for the work! Just one question :
|
No we keep the For example the export default {
base: 'inline-flex items-center justify-center text-gray-900 dark:text-white',
padding: 'px-1',
size: {
xs: 'h-4 min-w-[16px] text-[10px]',
sm: 'h-5 min-w-[20px] text-[11px]',
md: 'h-6 min-w-[24px] text-[12px]'
},
rounded: 'rounded',
font: 'font-medium font-sans',
background: 'bg-gray-100 dark:bg-gray-800',
ring: 'ring-1 ring-gray-300 dark:ring-gray-700 ring-inset',
default: {
size: 'sm'
}
} Here is the new version: export default {
base: 'inline-flex items-center justify-center text-gray-900 dark:text-white px-1 rounded font-medium font-sans bg-gray-50 dark:bg-gray-800 ring ring-gray-300 dark:ring-gray-700 ring-inset',
variants: {
size: {
xs: 'h-4 min-w-[16px] text-[10px]',
sm: 'h-5 min-w-[20px] text-[11px]',
md: 'h-6 min-w-[24px] text-[12px]'
}
},
defaultVariants: {
size: 'sm'
}
} This is a breaking change if you've overridden its config in your |
Ok ! Effectively, it's a breaking change but it seam ok for the future to have a better granularity with the variants. Thanks for the explanation and the example 🙏🏻 |
@MickL while on v2 docs, last I checked, v3 is not linked, on v3 docs v2 is indeed linked. I am also unsure of how this is a problem given that an official release is yet to happen and therefore, in my opinion, only people following this issue, who are willing to test it early, need to even know about its existence for now. Regarding the toast, I would have to disagree. There is a very distinctive difference between a toast and a notification in the programming world (web development is only one of the areas). A toast, by programming definition, is a small, unobstructive pop-up, typically in the corner of a page, meant to notify of non-critical information, like success/error messages. A notification, on the other hand, is a more prominent overlay meant to convey important information, like the notifications you get on your phone from apps/websites. Therefore, the toast should stay as toast because its name is true to its purpose, and it has nothing to do with food. Nuxt UI indeed provides a way to use toasts as notifications with further customization and actions, but it is still a toast in essence. (And regarding your off topic statement, toast can also be made from whole grain bread, it doesn't have to be white) And lastly, regarding types, I believe there are already a few PR's meant to address some aspects of it |
Personally I would recommend everyone who starts a new project "now" to use v3. Tailwind is in beta and Nuxt UI also looks kinda ready soon. Also v3 is implementing breaking changes everywhere. Personally I would even write a big heads up on the mainpage of Nuxt UI that v3 is coming up.
I dont see any difference between a "toast" as you say and a phone notification. On macOS the "toasts" are also called notifications and they have the same size as a Nuxt UI toast. They come in on the top right, not the direction of a physical toast (Offtopic: The "whole grains" are as unhealthy as normal ones) |
If you'd like, we could continue this topic privately to not clutter the issue, but essentially, as I said (though this time with slightly more details) a toast is a small non-intrusive unobstructive pop-up for general, non-critical feedback that goes away after a while automatically, not requiring any interaction from the user and not blocking anything, for example error/success messages. A notification doesn't go away automatically and requires interaction (like to dismiss or to read), is more obstructive and provides more critical details (like the example I provided with the notifications you get on your phone in the notification bar, which don't go away until you swipe them aside, or if you want an example from a website then the notification menu on YouTube which requires you to either click on it, hide it, or turn off all notifications from the source of the notification) |
On iOS and macOS the notifications are small, come in for a few seconds and go away automatically (on macOS optionally they can stay until user reacts) and they are called notification and not toast. What you describe is the notification center where notifications stay because normally they are visible only for a few seconds exactly like the "toast" component in Nuxt UI. |
Hi Benjamin! Just trying out Nuxt UI 3. I've noticed that with UInput the returntype of However an input with type export interface InputEmits {
(e: 'update:modelValue', payload: string | number): void
(e: 'blur', event: FocusEvent): void
(e: 'change', event: Event): void
} |
Hello Benjamin! Newbie to 3 questions:
Thank you! |
No sorry, I don't like Discussions and rather keep everything is Issues. Also, I'm using a tool called Volta (volta.net) made by me at NuxtLabs to manage open-source and it doesn't support Discussions.
|
Alright, nothing worked as expected on my side (existing Nuxt4 + TailwindCSS 4-beta project) but recreating my project based on Didn't even know about Sorry for bothering! |
@benjamincanac I was trying v3 for a bit and I just wanted to give you and everyone else who was involved my biggest respect and say that I am amazed by all the work that has been done! I was hoping for a bit of visual improvements, for example the examples Reka UI showcases look a bit cleaner to me. And I was not disappointed, I see tiny visual improvements everywhere, and an all new design for at least the Table which I really like. Further what I really like is that it seems way more customizable. Some things are not hardcoded anymore (e.g. button doesnt have Keep up the good work, cant wait for first beta! Btw I recommend everyone to use latest commit until next alpha comes out, because alpha 9 currently doesnt use Reka UI. @benjamincanac is pushing new commits kinda every minute, to install current latest commit: |
Hello, Looks like the new Dropdown lost @benjamincanac will this be added back or removed completely? I've still few issues that are still bugging me (I'll report later today) but looks nearly perfect. Thank you for the great work :) |
Hey Benjamin Any chance we can get click events on rows on the table? I'd like an entire row to navigateTo a different page. Currently not possible. |
Soon you could check this PR #2822 . I based it on the tanstack documentation https://tanstack.com/table/latest/docs/guide/row-selection#connect-row-selection-apis-to-ui, however it did not pass the tests Because I still don't have much experience in it, the idea was to do something similar to version 2 in which you could also use a @select event in this case to opt for Row Row APIs of tanstack and the click event |
I had a few of issues with @select in v2 especially in combination with buttons / dropdowns. But I also think being able to click an item would be super important! |
Exciting. Will be good to have. That will be the last thing I am missing. I am currently trying to implement column reordering, which is is possible with the API but I'd prefer drag and drop which is complex. |
Btw ordering is the only thing Nuxt UI is missing. Currently I use sortablejs in my project (but not within a table) |
I wouldn't know how to do drag and drop with the table, but sortablejs looks cool @MickL . Tanstack table is already a steep learning curve for me. I managed to get this working: And to make it more complex, I try to put all filters, sortings and column order in localStorage such that users can save their tables. |
Probably too late, but having a |
I was looking for this too! Actually exactly in this moment I integrated it myself but I would also appreciate if things like SelectMenu and InputMenu could have a clear/reset button or something |
you just have to clear the model value to unselect something, this can be easily achieved with a <script setup lang="ts">
const items = ref(['Backlog', 'Todo', 'In Progress', 'Done'])
const value = ref<string>()
</script>
<template>
<UButtonGroup>
<USelectMenu v-model="value" :items="items" class="w-48" />
<UButton icon="i-lucide-x" @click="value = undefined" />
</UButtonGroup>
</template> |
Thats how I did it. But you also need to keep track of if the reset button should be shown. For example one would say Imo it would make sense for this components to have a reset function built into Nuxt UI. BUT maybe there would be too many different requirements: One might want to be able to deselect a value in the select menu, this currently works only with |
@MickL That is exactly the reason why we've never implemented it, there are so many different possibilities to achieve this that it's easier to do it yourself honestly.
|
Oh wow this 1. is a nice solution. Maybe this example could be added to InputMenu and SelectMenu as well! Also maybe the other two points could be at least mentioned in the docs (may dont need a code example). What could be done tho for SelectMenu is the possibility to check an item off again? It works with multiple but not for single values. |
I'll add the examples! This would be an issue for Reka UI's |
Shouldnt be Drawer and Slideover the same component? As far as I see the only difference is that a Drawer has an optional handle. Slideover is missing the "swipe to close" feature, but this I would definitely add to it as it is a common user behavior using mobile devices. Personally I would remove Slideover, rename Drawer to Slideover and hide the handle by default. |
One thing I found a little confusing in the Nuxt UI Pro v2 documentation was trying to work out the difference between components with similar names: e.g. LandingCard vs PageCard or LandingGrid vs PageGrid. I had to look at the config code, but it would be good if the opening description had a little more detail to explain what that component did.
When you shrink the screen down to mobile mode, the default slot is left aligned instead of centre aligned like the left and right slots. |
Unfortunately, they are based on two completely separate tools, as you can read from the linked documentation.
This would be more of an upstream discussion. But I personally use them both, depending on UI design and project's device target. |
Doesnt it make sense to unify them when one is better supported? Personally I would love to use slideover but it doesnt have a swipe to close feature. Without the follow-pointer-movement, like Drawer has, it would be easily implemented by https://vueuse.org/core/useSwipe/ |
When do you plan to release dashboard for v3? |
The development is ongoing on the default branch of this repository: https://github.com/nuxt/ui.
A lot has changed since
@nuxt/ui
was made open-source (May 2023), so the plan here is to rewrite every component from scratch alongside their config.I'll post regular updates on this issue and on https://twitter.com/benjamincanac.
Documentation
https://ui3.nuxt.dev
Roadmap (Nov 20, 2024)
reka-ui@alpha
on@nuxt/ui
&@nuxt/ui-pro
(feat(module)!: migrate toreka-ui
#2448)@nuxt/ui-pro
components@nuxt/ui-pro
components (almost all are done except for Dashboard)@nuxt/ui
likeCalendar
(feat(Calendar): implement component #2618),DateInput
,Tree
(feat(Tree): implement component #2757),Stepper
(feat(Stepper): new component #2733), etc.@nuxt/ui
&@nuxt/ui-pro
officially oncetailwindcss
andreka-ui
are released@nuxt/ui-pro
components & templates like Changelog, Portfolio, etc.Breaking Changes
The biggest change is the switch to
tailwind-variants
, this will cause lots of breaking changes if you've used theui
prop orapp.config.ts
to override the config. I apologize in advance for this but I strongly believe this will be beneficial and will bring consistency across all components.The config will now have a
slots
amongst other keys that will specifically target dom nodes. Theui
prop will only allow you to target those slots.These changes alongside the refactor of all components will also improve the types, the
app.config.ts
andui
props are now perfectly typed, as well as all componentsprops
,slots
,emits
andexpose
.Components
The text was updated successfully, but these errors were encountered: