Love how we went full circle on dependency management there. From copying files on the internet into our own project, to complex package management and versioning, right back to copying code from the internet into our own project 😅
You could always copy code from NPM to your code, you just decided to not do this. Every dependency installed from NPM is literally copy pasted full source code into your project.
My guess is the final project will look like an early geocities page, because each component from a different author has a different idea which fonts, colors, sizes, margins etc. to use.
@@dancarter5595 What I meant is that this practice of copy-pasting AI-generated code (not only for UI, but also for logic) looks very brittle to me... how can you entrust any part of your business application to this? We are accustomed to not be 100% sure of our code even with heavy testing... piecing together some pregenerated bits like this looks terrible to me (personal feeling). (I was expanding on the "v0" part of the video)
THis is going to be hell to maintain lol. 100x boost in number of lines of code a developer can inject into the repo per hour, no change in number of lines of code a developer can read in the repo per hour.
Exactly. I don't mean to bash this stuff, its great but I'm using a 3rd. party tool to build blazor apps. Less lines of code, I have less time to read them and I don't really care about ownership. The app works! Great, on to the next one...
I also think the same until - we need to custom - change bootstrap to others and might have to rewrite the whole. its also plain mostly open source still need to maintain such as minor or major upgrade or even sunset. I not sure when we easier to develop but not difficult to maintain. write our owned code might be?
Correct me if I'm wrong, but that seems like a one way road to unmaintainable codebase, because I can see how it is faster to build something from scratch, but changing it after time is a frightening idea, especially without proper tests. It reminds me of old days where there was that one brilliant team that decided to fork library to make few changes, years goes by and that one library is becoming a liability which no one wants to touch and it contains old bugs which were fixed & forgotten in the rest of the world. And I've seen this many, many times in different environments. If my only goal was to build one perfect app based on perfect requirements that will never change then it's fine: I will use AI tools, generate tons of code, change it a bit and I can even minimize/pack it, the heck, I don't even need a git repository! It will never change! But we all know the world doesn't work like that, requirement change or are wrongly interpreted, that's why we care about maintainability. Average dev spends 8 times more time on READING code than on WRITING code, that's why every line of code in your repository is a liability, so you need reeeaaally good reason to put one in. But, well, maybe AI tools will get smart enough to comprehend such codebases and will make changes for us, but for now, code is for humans, and humans are limited, limited in memory, limited by mistakes they make, limited in time they have, so you need to keep it simple and clean if you ever want to change it in the future.
The idea is, a great developer will keep things and their code simple and not build the god ui that does everything. KISS, less is more! The other problems can be fixed with well documented code, or a dev doc that is maintained (like code). Also, each component should have its own unit tests. The test themself serve two purpose. Show usage and catch bugs early. What you seem to be complaining about, is some team with really bad software development practices.
@@RajinderYadav But you should know that's not how the world works. When was the last time a client switched to your company for maintaining a project and you actually got any meaningful Knowledge Transfer from the previous maintainers? From my experience any documentation provided is highly outdated and you basically have to fuck around and find out to build it and make any changes. And Unit tests are an endangered species as well.
"Average dev spends 8 times more time on READING code than on WRITING code" This is exactly why an approach like ShadCN's can work better. If you're committing to only installing code as a library, and accept every single line of it that is not relevant to your use case, you'll end up reading (and debugging) code that is significantly more complex than what you need, all the time.
I prefer tailwind+daisyUI nowadays. It's highly customisable and daisyUI provides some basic components to start with which are also highly customisable with tailwind unlike whatever the hell was mui
I end up writing a lot of administration ui in my day job, so i have a different perspective on this: I don't need all of this customizability for writing those kinds of UIs because nobody cares or pays for that. What I need are UI components that look good by default and are as simple to use as possible. Bootstrap is perfect for that.
@@MeonisRP Fair point. I prefer to be THE GUY that does the complicated features in less time and adds more convenience features though. In my experience that's appreciated way more by customers.
Completely agree. Customers and stakeholders don't care if you use the latest hot Twitter/Reddit tech. I've seen teams having to double the size of the frontend dev team to maintain their React+Tailwind+ monstrosity of a frontend while paying 5x the infrastructure cost. We get things done with Bootstrap and focus more on delivering high quality services where it matters.
Hmm I think this depends on your clients and projects. I work at an agency where we work a lot on dashboard UI projects that are either external or internal and we never use these UI libraries. They always end up blocking us in some way, whether it's styling which usually can be addressed, or worse UX which is usually harder to address because you have to fork the project or end up using some other component from some other package and style it. It also impacts designers and what they can do because it's not fun just assembling random UI library components and it's hard to know how much you can customize them as a designer to fit the project. We do still use libraries like Radix so that we get nice accessible headless components that we can control almost 100%, but fully styled libraries have been a pain point for us so we decided not to use them.
Nice video, tho it is not clear to me how you deal with updates if you don't use libraries anymore. To me that seems like the main point of having these as libraries/packages. If there is a bug in one of these components I am copy-pasting, and they fix it in the meantime, how do I update? How do I know there is an update? Would have been interesting to see that talked about.
I feel this is a symptom of this new iteration of web ui reaching maturity. People aren't worried about getting updates for their components because they feel they're already good enough. And things are understandable enough that fixing anything is something people are able to do themselves.
I work more on the backend so things are a little different, but, yeah, talking about this being “code you own” sounds like a nightmare There are times it’s frustrating to have to code around a bug or missing feature, but that’s missing the effort multiplying offered by packages If 100 companies use a package, it just takes 1 to identify a bug and the package to fix it for it to be fixed in 100 places With this, it has to be identified and fixed 100 times. They’ve in-sourced that maintenance My goal is to maintain as little code as possible. Sometimes that means building something small on top of a low level library, and sometimes that means building something big on top of a high level library So, this has its place, probably for smaller apps that won’t be adding much code this way Looking to the (near?) future, this will be viable for more projects when AI can own the app and its maintenance instead of just providing boilerplate
I feel like they didn't even try, or maybe I'm misunderstanding Even if they encouraged you to add in npm a package which has no code, but could interact with other dependency management systems like dependabot. When the package updates it won't modify your code but at least it tells you something changed you might want to look at The ai tools are fine I guess, because you're taking ownership of the code as if it was your own. But will people?
Spent a lot of time in public sector and bootstrap is %90 of what they use. We had ~1k websites at the uni I worked at, all built in bootstrap. Likewise azures power pages is all bootstrap, which was their new site builder this year. I think it's easy to get caught up in the react world, and there bootstrap is less popular, but these ui libraries are honestly still growing, just in different markets than what you see Imo
Exactly. Theo really lives in the react bubble. I'm a subcontractor for a lot of private international companies and I can tell u that bootstrap isn't going anywhere. Social media Web developers have a sickness for shiny toys.
Cool insights, thanks! But am I the only one doesn't buy into the "copy instead of npm install" thing? Shadcn depends quite literally on radixUI, which itself is installed in the background for you. I wonder how many files you would need to copy if we also wanted to let users copy vs. install radix into their components
Right?? I think the critical question is what level of aggregation is too much to have it done for you. What are the reliable "primitives" (to use an over-used term) that we should standardize on? Maybe ShadCN represents a better answer to the question than a lib like MUI. But I don't like the framing of "UI libraries are dying".
Yeah I'm not buying it yet. I looked it up and I would have to digest what I copy PLUS the underlying radix dependency. And many components are broken down into a dozen little component parts which, for example, with vue, it's not a good idea to have a bunch of component instances like this. If they didn't have a dependency I would be more sold. But idk I'm not sold on ANY component library. They all suck in their own ways. At least I know how the ones I make suck, I guess.
I think that frontend devs are going through all the problems IT had in the past and try all the solution that were already tried. I mean, there is nothing particularly bad about it - maybe previous generation of devs have missed something, maybe frontend is different from other software, but I kinda don't believe in it and will just go with approaches that are well established (in software engineering in general, not in frontend) and let them experiment on their own.
@@hariharansreenivas6752 good point! I confess that I haven’t tried stuff like MUI yet to know if you can install a single component or not there
ปีที่แล้ว +220
With real projects, it's not about how quickly you can start, but how it will be maintained and developed. Second thing: a lot of indirect dependencies = hell of dependencies and problems for teams that have to use some common system design or library (for example: problem with tree shaking).
The purpose of this new "librarires" is to have full transparency and control about the code you add in your project. Every dependencies are explicitly specify and replaceable We add what we need, we modify what we want If the project end up into hell dependencies, it's just a skill issue like a developer that copy paste every from stackoverflow in his codebase without understanding what the code does
I think it really depends on the person developing the code and who is managing it and what is the goal of the project. I would still use UI framework and library for developing UI in a foreseeable future for my projects.
It's all they have left to talk about. Udemy courses are dying because they tried creating 30-40 hour courses filled with utter filler, and hardly any of them know the languages they're teaching very well. They're experienced in creating pretty content at a shallow level. All of these UI libraries are an inch of water covering a mile radius.
Governments around the world still use technologies like PHP and dotnet, still relying primarily on frameworks like bootstrap (almost all Indian govt websites). They are not going anywhere, yet.
@@justin.johnson Bootstrap if still popular outside India too....People are too much emerged in the react world, they refuse to see the simplicity of using Bootstrap....Imagine a major update in react, you have to again rewrite your application and creating builds....
4 หลายเดือนก่อน
@@Argomundopeople still saying bad things about PHP because they are stuck in php5
I also started building my first pages using UI libraries like bootstrap, and I learned a lot about CSS and general DOM styling by analyzing the classes bootstrap brings. Later on I used Material UI for Agnular, and there started my aversion to these UI libraries, because you sometimes want to style things in their components a little bit differently. And to to so, you either can't entirely or you need to perform some super ugly trickery (ng-deep, I hated it so much) to modify and customize these stuff. On the other hand, there are some very nice and highly customizable component libraries out there, but then you need to literally study their way how to style and modify their components. So I just started do build my own components using Styled Components for React, which is a wonderful solution to be able to build modular components which you can copy from one project to another.
In my experience making your own styling components in real project makes things much worse. You want to ship your app as fast as possible. I can agree with you that these ui libs are sometimes hard to customize , but they give you everything that you need to start working on the application. What i suggest is pick a ui lib , try to customize it in a general way so all the other pages use the same components (ex : boostrap button btn-primary instead of blue is purple or modals) so everytime you use it you get the same for all components.
@@stunna4498 Don't even get me started on accessibility... It's better to use an unstyled component library and fulfill 90% of your needs than to spend ages with a custom component library
@@stunna4498 Bs. Customizing ui libs takes longer, than writing own stuff you can expand on in your desired way. Building dependencies is always not a good idea for starting up a business. Also when i think of UI libs that get updated nearly weekly doing things differently over and over ... it is most of the time a better choice to do things yourself. I hate that full service mentality, where you give everything in others hands.
@@bloozy85 well i can only speak for my experience . for example in my company we use alot of mui .Some components are hard to customize but you eventually overcome it and do it. Now building it from the ground up is a waist of time. I had a colleague who was said the same thing and created multiple customized components. everytime there was a change he had to waist weeks to fix it and making sure it would work in every single place you used that. No need to tell you how that project went. Unless there is a very good reason to make a component from the ground up , in my opinion it's a waist of time. sorry for my bad english
@@stunna4498 I think building components yourself can never be a waste of time, only because of the aspect of learning. If your companies dev, needs weeks to fix his own code, sry, then he is not a good dev :D But i see this a lot nowadays, devs can only copy & paste stuff and are not able to code basic things. And hey let's be honest, most of the UI lib stuff is basic stuff.
I also want to toss in that I think Vercel is a blight on the OSS ecosystem. They sell hosting, period. But their VC funds have allowed them to snatch up tons of OSS projects in an effort to control the narrative, acquire mind share, and steer development towards their business model.
I like Shadcn-ui, and use it a lot (well, shadcn-svelte more specifically), but it only works with frontend frameworks, when I'm not doing that, IMO Bootstrap (or Bulba, whatever) is still the better option simply by the fact that I can customize it SCSS, or I can just drop the CDN link in the and don't need to worry about anything else.
if you own component code base that means you are responsible from maintaining that codebase too. if you manipulate them in a significant way, that means you need to test it from start like you build it from scratch. i'm using ul library because i do not want to maintain frontend code. most of the time i just need basic styling and basic styling does not need maintain. i dont think this will replace bootstrap.
1) I want to see the upgrade path of these new "build your own component libs" tools. I have not seen an automatic way of doing it 2) None of these tools right now has good editable tables. Which is one of the hardest things to get right if you have bigger tables. 3) I can see the push back to solutions of tailwind because of the 1) and how hard it is to upgrade your large codebase. Its just a matter of time when more and more people will run into this problem.
@@kubakazimierczak6646 When you have a large codebase with a lot of components and you use for example the color green you now must go through every component and check if this is that green (okay simple search) and check if that green would need to be changed. What we have done we went for example from "colors" to intent with css vars. So instead of saying class="green" we have class="success". This also helps with theming. The other problem is with breaking changes in tailwind and how things work together. This with the combination of "copying someone elses code into your code base and then extending it" is nothing new and was already not very maintainable back in the days were you would buy component libs from vendors.
I think this has more to do with the necessity to make changes to UI components and not being strictly bound to the limitations of the library. It's not so much that the libraries are not useful.
What might also be useful is if we could try and settle on a fairly standard API for these common components and UI patterns. So you don't have to learn a different HTML structure with different tag and attribute names for each UI library.
I feel like these solutions offer both! The HTML structure will never be identical, so you can copy in the HTML structure everyone knows. And with shadcn, you can use name the exported components however you like.
@@JosueRodriguez08 That's not really what I'm talking about though. Web Components don't define a standardized syntax for declaring common GUI elements like (for example) accordions, carousels, and calendar views.
@@andybrice2711 the problem is that no one knows what is "the right" way to go with this and people argue about it, thus: different approaches. Some die, some keep living, but there is no consensus and I don't think there will be soon. If something is well established then it becomes the part of HTML, but that's quite rare - you already have and no one use it.
every time I watch videos like this, my position, as a curmudgeon is reinforced. I’m happy over here with my static websites, my HTML separated from CSS separated from JavaScript. I feel like 33 is too young to be a curmudgeon, but here I am lol
I don't understand how this is better than a UI library. You can iterate fast into a hellscape of incredibly complicated code that since you've never written it yourself you don't know how it works but you also don't have the benefit of being able to pull updates from professional teams of developers whose job it is to fix bugs in these systems.
As someone who sticks with own code, plain HTML/CSS as much as possible, UI libraries couldn't go away soon enough. But standard UI components should be built into HTML. For the most part, they are. I write my code to be standards-compliant and simple. Generating all the extra stuff, such as sitemaps, rss feeds, menus, fancy widgets from that on the fly. That way, if visitors don't have Javascript, or have an old browser, it still works the way I designed it.
But its still pulling in Radix as a dependency, so it's only slightly less removed on the normal model of pulling in a traditional UI library. Can't help but feel it's a sleight of hand trick.
Personally, I'm interested in UI libraries, but the reason I generally don't use them is that on most projects, I only need one component from it. That's usually fine if that's all, but what if I need one widget from UI library X and one from UI library Y (if not more). I'm now importing from big code bases that work differently, potentially add a lot of code to my bundle size, use different styles I have to customize, etc. I find that Bootstrap is another category than these component libraries, though. The main reason to use is to do responsive UIs without having to figure out the CSS for it yourself. That's still valuable for junior devs who have enough things to learn on their plate beside wrestling with the intricacies of CSS or Tailwind. But once you understand CSS Grid and container queries, responsive frameworks like Bootstrap feel like they add too much markup to your code.
I very much agree! I even think this will soon become the new web standard, maybe in HTML6-7. I really hope we will have native components that look more modern, support light and dark mode, and the api allows to be styled better. For example the input select, date picker, checkbox, radio buttons. Those are all really annoying to be styled.
Yup, there are two things websites which you guys like to call Web apps or some of you call them apps. Anything running from the browser is a website regardless of what type of website it is. Even if you’re running logic on the back end, it’s a website on a browser. Native Apps now that’s a different beast, that need better UIs or the ability to js and css directly on them. Then we have the fact that many libraries make end products look like clones, which happens by default because rarely do we have a new component we haven’t seen. UI for Native APPs or better css support without stacking frameworks.
UI Libraries are not dying, you're using Remix under the hood for the complex components. The change is that headless components are a trend now because opinionated customization is not on trend. It's just a matter of time before a company launches a new "material design" just like in 2014 and boom a whole new set of UI libraries emerges.
I do appreciate the fact that videos like this start debate and allow for a more specific and rich advice exchange (of sorts), but, I can't help but be annoyed at the fact that youtubers like him use plenty of clickbait-y titles making you think there is an actual revolutionary way of developing better and much more nicer web apps (sadly, on top of the mess that javascript is today), when in reality it's, more often than not, a stretched monologue on them being entitled to their opinions, telling you it's the best, the most efficient, the all-time-killer way of doing things, under titles such as "you need to start using bla bla RIGHT NOW", "this bla bla is the worst, try this...", and I'm not saying it's wrong to come up with an opinion and put it out in the internet, but I swear every webdev video or python video is just rant on people trying to code their way, and it feels kind of disheartening. Can we, for a second. just acknowledge, that the web is a mess and no cool component ui library or syntactical-sugar-feeding framework will fix it? I'm not an all time web developer, but I've been for a while now and even inside my team I can see them being entitled on whether Prime Ng or Angular Material is the best... idk, not really going anywhere, I just needed to vent a little 'cause, despite having so many veterans out here, I feel like there is a lot of immaturity in the web community still, and it's pretty uncool
I initially opted for Shadcn UI in developing our laboratory management app, but unfortunately, I found it to be less than satisfactory. While it boasts an appealing aesthetic, I encountered numerous instances where I had to handle many aspects manually. My preference lies in leveraging a component library that is not just visually pleasing but also comes pre-equipped with almost everything I require, sparing me the need to build components from scratch. After grappling with several challenges, I decided to integrate Mantine into our app. Mantine, with its comprehensive feature set, turned out to be the solution I was seeking. Now, I seamlessly combine Mantine with Tailwind, and the synergy has resulted in a remarkably positive development experience for our project.
Thanks I have a look at it and it is pretty cool. I think Shadcn-UI also satisfy my needs but I did need some adjustments because the underlying component they use are sometimes not adequate.
I've used bootstrap and material in the past, but although it was great getting started I usually ended up not using most of the library and also ended up overriding a lot I was using. Another thing I realized was that I actually needed very little CSS in the first place. So a couple of years ago I started a new project and decided to not use anything and just roll my own CSS from scratch. Not only did I end up with something incredibly lightweight, but I learned a lot in the process. With the use of some CSS variables I could also change the colors quite easily and so create themes for different clients. It was simple, it was fast, and it's just basic CSS with no build step.
That's the perfect example how to NOT use bootstrap... That way its sure way easier then rebuilding the whole needed css by yourself... cause who wants to have some extra work to make the own code look clean... I used Bootstrap, MaterialUI and a bunch of other stuff... and NEVER ever had i touched the bootstrap stuff... i wrote my own shit or i used what i got there... But changing Bootstrap Stuff or Library Stuff always sticks you to that specific version... and i hate everyone that make me fiddle that shit out later.... Its a mere horror to do so cause sometime somewhere need to split this shit again...
i have a great time with Shadcn, unlike other UI libraries, IT EASILY expands and modifies the components, and it sits perfectly in the middle. It is easily modifiable like tailwinds but also has a great just-get-go component like MUI. The only gripe is when you tried modified the underlying radix part, but that's kinda my problem not the shadcn itself
For me, the operative takeaway is around 5:35 - "if you are building a component library for your company". Therein lies the conundrum. Not everyone makes or needs custom component libraries. Also, when you are operating in an environment where the most precious resource is developer time, having a "*all* batteries included" library that covers, oh, let's say, 80-85ish % of the project needs, is much *much* more important than wasting precious dev time to implement "oh this little tiny funny thing that we imagined" - and it should be a product / project manager's role to tell to the customer "no son, we will implement it in such and such manner, you want fantastic beasts and find them too, the budget must be quadrupled". In other words: I like what I see but it's resource (as in Human Resource) heavy.
I love the concept, but i don't seen this working at enterprise companies out in the real job market. To me, design systems built with web components make the most sense at large scale. Big companies typically have multiple, silo'd teams, but upper management always wants a consistent UI across all products. Since most product teams at enterprise companies ive worked at have significantly different tech stacks, it would be impossible to align on using react only. Web components really shine as UI libraries in my opinion and they're only getting better
@@jonnielappen5916 yep for sure. UI's that are composed up of smaller components. We create recipes as stackblitz examples where I work and have had a lot of success with them.
@@utkarshraj1642 yup, where I work all 3 are used across 60+ products. Maintaining a framework specific component library is 3x the work and completely unnecessary. That's why we decided to build our UI components as web components and we have framework specific wrappers to make them even more seamless
If the engineering team exercising more ownership over UI code means the company as a whole exercises more ownership over the look and feel of the UI, this has the potential to be something great. I think a lot of teams tend to see "a good start" as "a good final product," but hopefully this style of UI library will help encourage teams to grow beyond square one.
I first using Bootstrap when I was using just plain HTML and CSS. But when I trying to starting to switch on react, I realized that it is more logical to built component by my self rather to relay on CSS framework. One more thing that some React UI problem is it's not gonna work on other framework using React. Lets say Headless UI doesn't run on next because of webpack.
Every couple of months I came back to watch a new Theo video, and every time the whole front-end ecosystem is dying and being reborn into something that will die in another couple of months. It's tiring
how is this glorified copy-pasting better? updating will be much harder than running npm update, especially if we make big changes to the original component and then have to merge them I understand having more control is needed sometimes, but most of the time, I want to be abstracted away from library code we need libraries that have both options: 1. they are npm installable 2. they have a copy source button (for the rare cases when I want to change the component source significantly)
A component library, especially when battle tested like Radix, will require much less update than customizations, so copy paste it's a good tradeoff IMO
"updating will be much harder than running npm update, especially if we make big changes to the original component and then have to merge them" -- if you make big changes to the original component, why would you be interested in updating that component from source again if you had to heavily modify it in the first place? It means you didn't really need the original implementation as it was. These copy-paste libraries are used as a good starting point that you can take almost full control over and are not at the mercy of the maintainers of the project to implement something and you can adjust them and do your own additional UX if that's needed.
Thank you. That’s what I’m saying, sometimes stacking classes becomes longer than typing the raw CSS, and if you been around you should have some classes that are used a lot. Is there native support for tailwind ? Or what makes it such a go to?
The only minor thing that I don't like about shadcn/ui is that the style is a bit too tech-ish by being so minimal and requires some work to make the style fit to a less tech corporate aesthetic. But I guess with time they will add enought customization options for this kind of requirement.
Isn't the whole point that it's unstyled/neutrally styled and you style it according to your brand? I hate presets, they never fit the brand, and customization is mostly done through super basic css, most of which is inherited anyways
@@readywhen yes, what I am saying is that if the branding is not going towards a tech aesthetic, as it is, you will need to do quite some work to adjust it and I wish there was an easy way to adjust it, don't care about presets at all
I have only watched through like halfway, but thank freaking god you showed this to me, my biggest pain point was the fact that very often I get asked to use a ui library for a project and get asked to create things that aren't working well with the UI library, or change stuff that you can't really just change it, you can in the ugly way, and I hated the freaking shadow elements always because it just pisses me off, hard to deal with and modify it because you aren't supposed to modify it, this makes that pain go away, in my recent times I was so mad I completely dropped UI libraries because what I want simply just isn't inside that library or is in but in a different way, so I have to rewrite it anyways then why not just do it from scratch because in all fairness, it isn't hard to rewrite especially if I already use a framework and use those tools with it and not the native JS ones.
Great video. From my perspective as a designer, I think this approach might make the design system turn into Frankenstein's monster really quick. At least you've brought AI into the discussion, which Vercel is really cooking up some cool stuff there with that component generator. I'm very curious how designers work into the fold with your approach, as I'm currently investigating whether to "go safe" with MUI recommendation for my PaaS client or instead assist them with building their own UI library with these newer frameworks like Radix along with Vercel's component generator. All I know is Tailwind CSS is super hot right now along with Framer Motion. NextUI is up and coming, but I like the idea of starting with basic components from Radix with zero design bias, whereas MUI introduces a lot of design bias with their Figma file. Don't get me started on MUI's [puke] icon library. Anywho, thanks so much for your bold perspective. People need that to get their head into AI these days. I'm curious to see what Google comes up with Gemini + Material Design. Very curious.
UI libraries aren't dying, we just have more options now. Theo, you saying that something is dying as a technology is kind of misleading, but I do understand that clickbait is required these days. You are close to bleeding edge all the time and also in Twitter bubble most likely as many of us here are. People have been saying for years that jQuery is dead, but it's still probably in 50% of top 10000 sites and has like 8 million weekly downloads on NPM. This is for a library that is probably mostly still included as a CDN link and not installed through npm. Reality is just different compared to our bubble.
Predicting what front end libraries will die or will become popular feels like astrology for nerds. I like learning all these new things, and shadcn/ui loos great, but I bet I’ll still be running into bootstrap or material up for a while to come.
I am sorry I failed to understand the difference between installing radix or a component from another component library. Don't get me wrong I love radix and how easy it is to use and transform to fit the design. But saying we are no longer installing component libraries instead we are installing radix, this is the part I don't understandd.
It’s a kinda sorta but not really solution. Coincidentally a radix problem was what I initially ran into, I believe it was the carousel. Keep in mind I installed a fresh react just to test shadcn, followed the instructions, had to watch a tutorial by an end user to get it to work, which included some tweaks not in the tutorial. Personally I keep asking myself should I just code it from scratch because this is more about fixing breaks that coding. The idea is good but they don’t flow at fast speeds. AI can now generate the js, and backend. OK time to try another UI then watch it break and have to break my head to make one button sample work. Then on to the next UI I must test them all. I’m UI greedy! It’s an illusion for the most part, of feeling like you’re up to date, but rarely is a new component created.
i kinda understand the benefits, but lets take daisyui for comparison. all daisy does is provide classes that are using tailwind classes. therefore i can use daisy default and then a little of my tailwind to customize and i still have it in its own component and i can fully customize it. no?
@@lechproteanTheo is a junior to me. I just occasionally watch for inspiration. I have already worked with React for a few years, but never really got into CSS.
That's just a worse fork. We should instead have a CLI that automatically forks a package and set it up locally in your project. Then you'd be able to pull changes as the package update, while keeping your changes
*Summary* * *(**0:00**)* *UI Libraries like Material UI and Bootstrap are becoming less popular.* The video argues that they are "dying." * *(**0:26**)* *The future is shifting towards building custom component libraries or leveraging tools that generate component code directly into your project.* This gives developers more control and avoids the limitations of pre-built libraries. * *(**0:56**)* *Shadcn/ui and Tailwind UI are leading this shift.* These tools provide pre-built components and the infrastructure to create custom ones. Instead of installing a whole library, you copy the code you need into your project. * *(**4:56**)* *This approach offers a balance between the speed of using a UI library and the flexibility of building everything from scratch.* You can start with pre-made components and easily customize them. * *(**5:56**)* *Tools like Vercel's v0 (VD) use AI to generate component code based on your descriptions, further simplifying the process.* * *(**10:55**)* *This shift is enabled by underlying technologies like Radix UI and Headless UI, which provide accessible, unstyled UI components.* This lets developers focus on styling and functionality. * *(**12:45**)* *Ultimately, the video argues that this new approach will lead to more accessible, customized, and maintainable user interfaces.* In essence, the video suggests a paradigm shift in how front-end developers build UIs, moving away from bulky, opinionated UI libraries to a more modular and customizable approach that emphasizes individual project needs. Summarized by AI model: gemini-1.5-pro-exp-0801 Cost (if I didn't use the free tier): $0.0637 Input tokens: 16335 Output tokens: 619
I wish you’d talk about Chakra UI sometime. It has a ton of features that scale from small to large projects. Everything any other lib can do, Chakra can also do. You can make your own component library with it as well.
Chakra can’t avoid having a runtime. That’s why they built Panda to replace it. Also, Chakra doesn’t work crossplatform (React Native plus web). But Tamagui can.
I feel like we are just running around in circles and reinventing wheels just to satisfy some urge to invent stuff. Component libraries are fine and they are not dying, they are actually very popular. And most importantly, they save A LOT of time and money.
Yes and no. AI now gets you to point B faster than attempting to learn framework languages and fixing breaks in the code. The next level is no code. A GUI build of the visual. With AI working on state and logic. Obviously people will use what they know. We run around testing every UI to render one component. Then go test the next library. The bottom line is , is the new generation of coders willing to learn the whole framework and the frameworks mini language to get up to speed. When AI can guide them in one or two days and build the code from scratch saving so much resources by not loading so much unused code.
They save time and money in some cases but not in others. Writing code doesn’t take that long if you know what you are doing. These libraries definitely do not save time if you want to do something that they make very difficult. In those cases, you wished you just built it all from scratch.
I would really like to know what practical stuff can you make with any of your tools that I'm not able with pug+bootstrap. I've been asking around for some time, but haven't got any answers worth a second thought
Tailwind has a build file that you can customize. We technically build a style element into html blocks, containing just the styling for that component. Gets triggered whenever I save an html file in that directory. But its nice that I can just alter that, if I have to.
the big problem with shadcn/ui is that I cannot use it since I do not use tailwind, so I'd have to recreate styles myself and at that point I might as well just stick to Radix
I think it's good. I'm a new developer who learnt UI with Bootstrap. But few things that have always irked me with it is that I get a bunch of components I don't need in my applications and it can be sometimes clumsy to do your custom component styling. Seems like this is a much lighter and flexible method for future UI.
Hi Theo, As a preface for my comment. I'd like to mention that I don't particularly agree with a lot of your viewpoints (especially around backend) but I do respect your insights as a developer. My experience is coming from the background of a primarily backend developer and entrepreneur that believes in low to no dependencies, and emphasizing unique user interfaces that correspond to the businesses unique branding. You're take on user interfaces is accurate in the sense that it'd better to have a UI within the application itself instead of a library (actually reminds me of a internal cli tool I made to embed my atomic design into any application directly so I could modify it as necessary in a way that's inline with that unique application.) Basically the current issue with component libraries is when you want to customize the look, it becomes very complex to do and you need to modify the code within node_modules which isn't optimal in any way. What I don't agree with is your take on shade. Personally I don't like it and have no interest in using it. While this does partially come from my unwillingness to use anything vercel (which is basically just a company that took over the primary usage of the react framework and added a Bunch of things to it to make developers lives "easier" and I'm sure they do but in reality most of what they make is just a giant dependency tying you to this company and that's exactly what they want $$$) Shade provides these pieces of functionality that you mentioned are a pain to make. And I can tell you they are. But the issue is that shouldn't matter. As developers we should have knowledge of the entire E2E codebase. Meaning we can build the ui, the frontend, the backend, the infra, the database, etc. I don't believe in segmentation of responsibilities because then you're in trouble when that knowledgable person leaves. Instead as developers we should be able to build the entire stack end to end. I'm not saying you need to build your own http library but most of the code should be your own. Where this intersects in UI is the (just use this libraries functionality) aspect. UI is complex and by just using these components without internal knowledge of how they work you'll inevitably come to the point of (damn I need to read all this code I didn't write). Instead I propose a "creating your own shite approach". Meaning if I'm working for company X, company X has a unique way that they want to be perceived by the world. Instead of trying to retrofit these libraries created for other companies use cases (or as a way to add a dependency between you and a company) look to your client you should be creating a unique ui system for company X with matching style guides. The atomic components that are created for company X should be contained within a storybook application that's separate from all other applications for easy reference. I then attach this to my cli app and have developers just run the cli to embed the atomic design into their application. So I don't have to repeatedly create the same functionality over and over I just have an internal (to me) library that contains all the different components that I would use in a typical application. Essentially my own component library. From this I can just pull the code I've already written over, modify the style of it to match them, add it to storybook and done. The best part is I understand all the code I produce. Fully. With corresponding documentation all in the storybook app.
I think it would be nice to have a native way to customize the look and feel of the checkboxes and select field. I really gussed by the title of the video that it would be something on this direction :(. Other than that I don't see those UI frameworks dying, I would say that we can maybe see they migrating to this same path.
So, why in the docs do they not say that this is a React components? I hate it when libraries assume everyone uses React. No, there is a sane world out there that doesn't use React.
I remember fighting with Bootstrap so many times because it did only 90% of what we wanted while we didn't need 50% of its features, and the remaining 10% were almost impossible to add in a meaningful way. I ripped Bootstrap out of multiple projects to build a custom UI library. This approach is much better! I really have to look more into Radix and Headless UI! Shadcn/ui also looks great, but we are not using Tailwind and personally I'm also not 100% sold on it. I prefer writing CSS to get full access to all its features, e. g. custom properties, container queries etc.
Now is the best time for this, because you should know how to make tweets and know your terms to have AI assist you in coding heavy js logic. HTML and css is simple. Goes further and databases are now easy too.
Yep, I'm just catching up from 7 years out of the industry, and I'm back to full circle today: - writing my own libraries in vanilla and/or TS to cope with types, and basic things like ranges and number epsilon stuff. - figuring out what primitives I can/can't have that are compatible broadly from MDN, like I can't use DOMMatrix yet, but transform is on the table. - eslint, but I'm going with stylistic and abandoning prettier. - abandoning vite and vitest because files that are scrambled and named adslhsetg aren't okay. - back to es6 module imports without @s. I *am* using JSX because it allows me to write stuff declarative *slightly* better than using template strings, but I'm open to hearing things.
I like the idea of CDN's but we all know they're unreliable. I also think that having to "npm" libraries is one of the dumbest things ever. Why hasn't a solution come out where you can simply download a "library" into each of your project folders? "npm"ing to me is like requiring machines that run Java applications to have Java running on their machines.
Do you want your MacOS code or Windows code in your project as well? Ever heard of open/close principle? We want to use a good to go component that can be configured with a small manageable number of parameters. That's it. We don't want to look into its UGLY code inside (or pretty).
No, they're not dying. Frontend devs are just in a bubble with React, Tailwind and all these complicated things. Bootstrap will never die for backend devs. They know what I'm saying.
I have a friend that claims we went to this hyper complex front end being separated from the backend was in order to make engineers more "plug and play" in service to capital. So your engineers were basically disposable cogs.
Haven't done much react yet, I've been helping a friend with their project where they are mainly using Vue. I'm relatively new to the whole component UI structure and can see the benefit that it's more templated components that get created. Helpful video, and understand your point of view.
If the shadcn/ui devs improve one of their components, how do you bring these improvements into your own (possibly modified) codebase? Just go through the changes one by one and copy-paste?
We struggle to deal with the tradeoff of of having perfectly working UI from libraries and them being too hard to customize, so end up building a lot of components from scratch This seems like a good compromise Is there something like this for angular as well? Or is it already built in a way that it can be used from any framework?
If you go to the documentation you'll see there are some frameworks supported via the cli method and you can make the manual installation too (don't know if this makes angular compatible though)
@@awol2 I believe the original shadcn/ui works for jsx/tsx, so frameworks like Angular, Vue or Svelte aren't supported by the original shadcn/ui, but there are heavily inspired implementations for these frameworks: Angular has spartan/ui, Vue has shadcn/vue and Svelte has shadcn-svelte. I don't know if the original creators of shadcn/ui are involved with these, but they look just as good,. though I haven't worked with any of them.
maybe maybe. I'm not against this pattern at all for some use cases. I really like the trend of moving towards prioritising simpler codebases with less deps instead of large deps with large wrapper code to make use of it. It always ends up being the devs that add stuff thats too complex and not being ruthless about cutting fat of apps they build.
Then you're not cut out for the fabulous world of modern front end! Where literally everything is just mind numbing, bug-ridden configuration! If you want to actually engineer anything, you'll have to make your own framework for the app builders to spend all day trying to configure :)
I'd be willing to bet bootstrap will far outlive shadcn ui. Don't get me wrong, I think shadcn and radix are cool and I think unstyled components are a great pattern, but the web is larger than React and sometimes you don't want/need to build your own design system from scratch
If you make your components git submodules you can still version, pin and update them in a central place if you want to reuse them across many projects
This might be a trend. This might solve extreme use cades. I don’t eanna go into this direction with a product that is not a component library on its own.
I think I'm in agreement with this. I much prefer this way of owning the code for your components. It also helps down the line when you have a project that goes into maintenance mode and then someone comes back to your code a few years later to "add a thing" and now your dependencies are out of date and it can rapidly get messy. So I think this helps with future-proofing your code.
Big upvote from me. This game me a lot of useful tools to use. I've never been sold on the traditional component libraries and enjoy having full control over the component myself and would spend time recreating components just to have them in my project and be fully curated by me. I love this approach and will be adopting this.
for me working with backend and front end for more than 15yrs, I would still stick with Bootstrap and manual CSS, You can easily solve any issue with complex PSD design/layout to CSS/HTML if you have the knowledge and understanding the core code of CSS.
Love how we went full circle on dependency management there.
From copying files on the internet into our own project, to complex package management and versioning, right back to copying code from the internet into our own project 😅
We have been going full circle with everything in frontend lol
You could always copy code from NPM to your code, you just decided to not do this. Every dependency installed from NPM is literally copy pasted full source code into your project.
hahaha Yes! I was about to say this was the EXACT experience using Bootstrap when it just came out
@@TheTigerus I'm not saying that you couldn't, but I'm talking about what the community at large advocated for.
just like clothing. trends are bs
Excellent, now I have 40 new UI components in my codebase to maintain.
Haha! Thats very true 😂
My guess is the final project will look like an early geocities page, because each component from a different author has a different idea which fonts, colors, sizes, margins etc. to use.
What a mess AI-generated programming is going to be (for those who are willing to use it)
@@atava85 huh?
@@dancarter5595 What I meant is that this practice of copy-pasting AI-generated code (not only for UI, but also for logic) looks very brittle to me... how can you entrust any part of your business application to this? We are accustomed to not be 100% sure of our code even with heavy testing... piecing together some pregenerated bits like this looks terrible to me (personal feeling). (I was expanding on the "v0" part of the video)
THis is going to be hell to maintain lol. 100x boost in number of lines of code a developer can inject into the repo per hour, no change in number of lines of code a developer can read in the repo per hour.
Exactly. I don't mean to bash this stuff, its great but I'm using a 3rd. party tool to build blazor apps. Less lines of code, I have less time to read them and I don't really care about ownership. The app works! Great, on to the next one...
Wait until AI assisted maintenance becomes mainstream
I like the approach. I also wonder about the optimization of resulting bundle size and tree shaking when every app has to handle that itself.
I also think the same until
- we need to custom
- change bootstrap to others and might have to rewrite the whole. its also plain
mostly open source still need to maintain such as minor or major upgrade or even sunset.
I not sure when we easier to develop but not difficult to maintain. write our owned code might be?
@@TheBrister123 Just delete your app and remake it, instead of trying to edit it.
Correct me if I'm wrong, but that seems like a one way road to unmaintainable codebase, because I can see how it is faster to build something from scratch, but changing it after time is a frightening idea, especially without proper tests. It reminds me of old days where there was that one brilliant team that decided to fork library to make few changes, years goes by and that one library is becoming a liability which no one wants to touch and it contains old bugs which were fixed & forgotten in the rest of the world. And I've seen this many, many times in different environments.
If my only goal was to build one perfect app based on perfect requirements that will never change then it's fine: I will use AI tools, generate tons of code, change it a bit and I can even minimize/pack it, the heck, I don't even need a git repository! It will never change! But we all know the world doesn't work like that, requirement change or are wrongly interpreted, that's why we care about maintainability. Average dev spends 8 times more time on READING code than on WRITING code, that's why every line of code in your repository is a liability, so you need reeeaaally good reason to put one in.
But, well, maybe AI tools will get smart enough to comprehend such codebases and will make changes for us, but for now, code is for humans, and humans are limited, limited in memory, limited by mistakes they make, limited in time they have, so you need to keep it simple and clean if you ever want to change it in the future.
I never read code. If there's a bug, i erase everything and restart.
@@reed6514 BASED
The idea is, a great developer will keep things and their code simple and not build the god ui that does everything. KISS, less is more!
The other problems can be fixed with well documented code, or a dev doc that is maintained (like code).
Also, each component should have its own unit tests. The test themself serve two purpose. Show usage and catch bugs early.
What you seem to be complaining about, is some team with really bad software development practices.
@@RajinderYadav But you should know that's not how the world works. When was the last time a client switched to your company for maintaining a project and you actually got any meaningful Knowledge Transfer from the previous maintainers? From my experience any documentation provided is highly outdated and you basically have to fuck around and find out to build it and make any changes. And Unit tests are an endangered species as well.
"Average dev spends 8 times more time on READING code than on WRITING code" This is exactly why an approach like ShadCN's can work better. If you're committing to only installing code as a library, and accept every single line of it that is not relevant to your use case, you'll end up reading (and debugging) code that is significantly more complex than what you need, all the time.
I’m not convinced that this is better than a UI library for small/medium scale projects
It depends, as always. There is no one solution to rule them all.
@@lunarcdr3083 don't tell reddit that! ahaha
He speaks about trends. ;)
Yeah, me neither.
Haven't watched it yet but my guess is its prolly about shadcn
quite literally written in description.
I prefer tailwind+daisyUI nowadays. It's highly customisable and daisyUI provides some basic components to start with which are also highly customisable with tailwind unlike whatever the hell was mui
@@deniswastaken sad bully
@@mirfan-2020 i want to move away from that approach, but I like it, and use it extensively at this point.
Hahah legend
I end up writing a lot of administration ui in my day job, so i have a different perspective on this:
I don't need all of this customizability for writing those kinds of UIs because nobody cares or pays for that.
What I need are UI components that look good by default and are as simple to use as possible. Bootstrap is perfect for that.
fair point
You should always do a little bit more than needed. That's how you become THE GUY
@@MeonisRP Fair point. I prefer to be THE GUY that does the complicated features in less time and adds more convenience features though.
In my experience that's appreciated way more by customers.
Completely agree. Customers and stakeholders don't care if you use the latest hot Twitter/Reddit tech. I've seen teams having to double the size of the frontend dev team to maintain their React+Tailwind+ monstrosity of a frontend while paying 5x the infrastructure cost. We get things done with Bootstrap and focus more on delivering high quality services where it matters.
Hmm I think this depends on your clients and projects. I work at an agency where we work a lot on dashboard UI projects that are either external or internal and we never use these UI libraries. They always end up blocking us in some way, whether it's styling which usually can be addressed, or worse UX which is usually harder to address because you have to fork the project or end up using some other component from some other package and style it. It also impacts designers and what they can do because it's not fun just assembling random UI library components and it's hard to know how much you can customize them as a designer to fit the project.
We do still use libraries like Radix so that we get nice accessible headless components that we can control almost 100%, but fully styled libraries have been a pain point for us so we decided not to use them.
Nice video, tho it is not clear to me how you deal with updates if you don't use libraries anymore.
To me that seems like the main point of having these as libraries/packages.
If there is a bug in one of these components I am copy-pasting, and they fix it in the meantime, how do I update? How do I know there is an update?
Would have been interesting to see that talked about.
I feel this is a symptom of this new iteration of web ui reaching maturity. People aren't worried about getting updates for their components because they feel they're already good enough.
And things are understandable enough that fixing anything is something people are able to do themselves.
I guess so but if you also end up modifying your copy a lot, it might not always be obvious how to integrate their new changes
I work more on the backend so things are a little different, but, yeah, talking about this being “code you own” sounds like a nightmare
There are times it’s frustrating to have to code around a bug or missing feature, but that’s missing the effort multiplying offered by packages
If 100 companies use a package, it just takes 1 to identify a bug and the package to fix it for it to be fixed in 100 places
With this, it has to be identified and fixed 100 times. They’ve in-sourced that maintenance
My goal is to maintain as little code as possible. Sometimes that means building something small on top of a low level library, and sometimes that means building something big on top of a high level library
So, this has its place, probably for smaller apps that won’t be adding much code this way
Looking to the (near?) future, this will be viable for more projects when AI can own the app and its maintenance instead of just providing boilerplate
I feel like they didn't even try, or maybe I'm misunderstanding
Even if they encouraged you to add in npm a package which has no code, but could interact with other dependency management systems like dependabot. When the package updates it won't modify your code but at least it tells you something changed you might want to look at
The ai tools are fine I guess, because you're taking ownership of the code as if it was your own. But will people?
I'm wondering the same thing. Even if the CLI and website would offer some kind of merging tool, it would still be painful.
Spent a lot of time in public sector and bootstrap is %90 of what they use. We had ~1k websites at the uni I worked at, all built in bootstrap. Likewise azures power pages is all bootstrap, which was their new site builder this year. I think it's easy to get caught up in the react world, and there bootstrap is less popular, but these ui libraries are honestly still growing, just in different markets than what you see Imo
Exactly. Theo really lives in the react bubble. I'm a subcontractor for a lot of private international companies and I can tell u that bootstrap isn't going anywhere. Social media Web developers have a sickness for shiny toys.
@@thagreatone402 just use vanilla css or tailwind ... bootstrap is dead
Cool insights, thanks! But am I the only one doesn't buy into the "copy instead of npm install" thing? Shadcn depends quite literally on radixUI, which itself is installed in the background for you. I wonder how many files you would need to copy if we also wanted to let users copy vs. install radix into their components
Yeah but with radix you only install a specific component not the whole radix library.
Right?? I think the critical question is what level of aggregation is too much to have it done for you. What are the reliable "primitives" (to use an over-used term) that we should standardize on? Maybe ShadCN represents a better answer to the question than a lib like MUI. But I don't like the framing of "UI libraries are dying".
Yeah I'm not buying it yet. I looked it up and I would have to digest what I copy PLUS the underlying radix dependency. And many components are broken down into a dozen little component parts which, for example, with vue, it's not a good idea to have a bunch of component instances like this. If they didn't have a dependency I would be more sold. But idk I'm not sold on ANY component library. They all suck in their own ways. At least I know how the ones I make suck, I guess.
I think that frontend devs are going through all the problems IT had in the past and try all the solution that were already tried. I mean, there is nothing particularly bad about it - maybe previous generation of devs have missed something, maybe frontend is different from other software, but I kinda don't believe in it and will just go with approaches that are well established (in software engineering in general, not in frontend) and let them experiment on their own.
@@hariharansreenivas6752 good point! I confess that I haven’t tried stuff like MUI yet to know if you can install a single component or not there
With real projects, it's not about how quickly you can start, but how it will be maintained and developed. Second thing: a lot of indirect dependencies = hell of dependencies and problems for teams that have to use some common system design or library (for example: problem with tree shaking).
The deps are Tailwind and Radix, pretty far from hell. It's your code, not a black box. How's that not maintainable?
@@anttihilja but it will never be just only Radix + Tailwind.
@ So you just build everything from scratch with vanilla js?
@ If you don't like the other deps you can remove them, because it's your code. You rather have the deps a black box you have not control over?
The purpose of this new "librarires" is to have full transparency and control about the code you add in your project.
Every dependencies are explicitly specify and replaceable
We add what we need, we modify what we want
If the project end up into hell dependencies, it's just a skill issue like a developer that copy paste every from stackoverflow in his codebase without understanding what the code does
I think it really depends on the person developing the code and who is managing it and what is the goal of the project. I would still use UI framework and library for developing UI in a foreseeable future for my projects.
Or if you're already using bootstrap on a 5000+ page site. We just dropped jQuery from the entire website. In the long run he's right though.
Javascript horoscope 2024: There will be many more meetings about which UI library to use and whether or not you should be required to build one.
Javascript horoscope 😂😂😂😂
HAAHAHHHAAHHA
That is called junior front-end web development
"UI Libraries are dying, here's another UI library", web dev 2024 ladies and gentlemen.
It's all they have left to talk about. Udemy courses are dying because they tried creating 30-40 hour courses filled with utter filler, and hardly any of them know the languages they're teaching very well. They're experienced in creating pretty content at a shallow level. All of these UI libraries are an inch of water covering a mile radius.
Governments around the world still use technologies like PHP and dotnet, still relying primarily on frameworks like bootstrap (almost all Indian govt websites). They are not going anywhere, yet.
Dotnet is not legacy
@@curtisw0234Nor is PHP.
You havnt touched PHP in a long time have you?
@@justin.johnson Bootstrap if still popular outside India too....People are too much emerged in the react world, they refuse to see the simplicity of using Bootstrap....Imagine a major update in react, you have to again rewrite your application and creating builds....
@@Argomundopeople still saying bad things about PHP because they are stuck in php5
everything is dying except facebook's products, am i right?
React is going to be the new Java
@matiasmiller6119
This statement is so wrong on so many levels Im impressed
I also started building my first pages using UI libraries like bootstrap, and I learned a lot about CSS and general DOM styling by analyzing the classes bootstrap brings. Later on I used Material UI for Agnular, and there started my aversion to these UI libraries, because you sometimes want to style things in their components a little bit differently. And to to so, you either can't entirely or you need to perform some super ugly trickery (ng-deep, I hated it so much) to modify and customize these stuff. On the other hand, there are some very nice and highly customizable component libraries out there, but then you need to literally study their way how to style and modify their components. So I just started do build my own components using Styled Components for React, which is a wonderful solution to be able to build modular components which you can copy from one project to another.
In my experience making your own styling components in real project makes things much worse. You want to ship your app as fast as possible. I can agree with you that these ui libs are sometimes hard to customize , but they give you everything that you need to start working on the application. What i suggest is pick a ui lib , try to customize it in a general way so all the other pages use the same components (ex : boostrap button btn-primary instead of blue is purple or modals) so everytime you use it you get the same for all components.
@@stunna4498 Don't even get me started on accessibility... It's better to use an unstyled component library and fulfill 90% of your needs than to spend ages with a custom component library
@@stunna4498 Bs. Customizing ui libs takes longer, than writing own stuff you can expand on in your desired way. Building dependencies is always not a good idea for starting up a business. Also when i think of UI libs that get updated nearly weekly doing things differently over and over ... it is most of the time a better choice to do things yourself. I hate that full service mentality, where you give everything in others hands.
@@bloozy85 well i can only speak for my experience . for example in my company we use alot of mui .Some components are hard to customize but you eventually overcome it and do it. Now building it from the ground up is a waist of time. I had a colleague who was said the same thing and created multiple customized components. everytime there was a change he had to waist weeks to fix it and making sure it would work in every single place you used that. No need to tell you how that project went. Unless there is a very good reason to make a component from the ground up , in my opinion it's a waist of time. sorry for my bad english
@@stunna4498 I think building components yourself can never be a waste of time, only because of the aspect of learning. If your companies dev, needs weeks to fix his own code, sry, then he is not a good dev :D
But i see this a lot nowadays, devs can only copy & paste stuff and are not able to code basic things. And hey let's be honest, most of the UI lib stuff is basic stuff.
I also want to toss in that I think Vercel is a blight on the OSS ecosystem. They sell hosting, period. But their VC funds have allowed them to snatch up tons of OSS projects in an effort to control the narrative, acquire mind share, and steer development towards their business model.
Does “blight” mean good or bad
@@TheSaintsVEVOcolloquially it does not
@@TheSaintsVEVObad. Disease
@@TheSaintsVEVO It means bad
@@PremPatel-s2q thanks
I like Shadcn-ui, and use it a lot (well, shadcn-svelte more specifically), but it only works with frontend frameworks, when I'm not doing that, IMO Bootstrap (or Bulba, whatever) is still the better option simply by the fact that I can customize it SCSS, or I can just drop the CDN link in the and don't need to worry about anything else.
if you own component code base that means you are responsible from maintaining that codebase too. if you manipulate them in a significant way, that means you need to test it from start like you build it from scratch.
i'm using ul library because i do not want to maintain frontend code. most of the time i just need basic styling and basic styling does not need maintain.
i dont think this will replace bootstrap.
1) I want to see the upgrade path of these new "build your own component libs" tools. I have not seen an automatic way of doing it
2) None of these tools right now has good editable tables. Which is one of the hardest things to get right if you have bigger tables.
3) I can see the push back to solutions of tailwind because of the 1) and how hard it is to upgrade your large codebase. Its just a matter of time when more and more people will run into this problem.
Can you elaborate more on "how hard it is to upgrade your large codebase"? I don't think I understand this point.
@@kubakazimierczak6646 When you have a large codebase with a lot of components and you use for example the color green you now must go through every component and check if this is that green (okay simple search) and check if that green would need to be changed. What we have done we went for example from "colors" to intent with css vars. So instead of saying class="green" we have class="success". This also helps with theming. The other problem is with breaking changes in tailwind and how things work together. This with the combination of "copying someone elses code into your code base and then extending it" is nothing new and was already not very maintainable back in the days were you would buy component libs from vendors.
I think this has more to do with the necessity to make changes to UI components and not being strictly bound to the limitations of the library. It's not so much that the libraries are not useful.
What might also be useful is if we could try and settle on a fairly standard API for these common components and UI patterns. So you don't have to learn a different HTML structure with different tag and attribute names for each UI library.
radix-ui feels close to that, there are implementations for react and vue at least
I feel like these solutions offer both! The HTML structure will never be identical, so you can copy in the HTML structure everyone knows. And with shadcn, you can use name the exported components however you like.
Webcomponents already exist, lol
@@JosueRodriguez08 That's not really what I'm talking about though. Web Components don't define a standardized syntax for declaring common GUI elements like (for example) accordions, carousels, and calendar views.
@@andybrice2711 the problem is that no one knows what is "the right" way to go with this and people argue about it, thus: different approaches. Some die, some keep living, but there is no consensus and I don't think there will be soon. If something is well established then it becomes the part of HTML, but that's quite rare - you already have and no one use it.
every time I watch videos like this, my position, as a curmudgeon is reinforced.
I’m happy over here with my static websites, my HTML separated from CSS separated from JavaScript.
I feel like 33 is too young to be a curmudgeon, but here I am lol
I don't understand how this is better than a UI library. You can iterate fast into a hellscape of incredibly complicated code that since you've never written it yourself you don't know how it works but you also don't have the benefit of being able to pull updates from professional teams of developers whose job it is to fix bugs in these systems.
As someone who sticks with own code, plain HTML/CSS as much as possible, UI libraries couldn't go away soon enough. But standard UI components should be built into HTML. For the most part, they are. I write my code to be standards-compliant and simple. Generating all the extra stuff, such as sitemaps, rss feeds, menus, fancy widgets from that on the fly. That way, if visitors don't have Javascript, or have an old browser, it still works the way I designed it.
Jesus will be impressed on the resurrection skill set.
But its still pulling in Radix as a dependency, so it's only slightly less removed on the normal model of pulling in a traditional UI library. Can't help but feel it's a sleight of hand trick.
In minutes you can deduct this. It was a “kinda”…
Personally, I'm interested in UI libraries, but the reason I generally don't use them is that on most projects, I only need one component from it. That's usually fine if that's all, but what if I need one widget from UI library X and one from UI library Y (if not more). I'm now importing from big code bases that work differently, potentially add a lot of code to my bundle size, use different styles I have to customize, etc.
I find that Bootstrap is another category than these component libraries, though. The main reason to use is to do responsive UIs without having to figure out the CSS for it yourself. That's still valuable for junior devs who have enough things to learn on their plate beside wrestling with the intricacies of CSS or Tailwind. But once you understand CSS Grid and container queries, responsive frameworks like Bootstrap feel like they add too much markup to your code.
My biggest issue with Bootstrap and other ui libraries is how hard it is to make it feel organic in a project. Bootstrap always looks cheap to me.
Clone.
I very much agree! I even think this will soon become the new web standard, maybe in HTML6-7. I really hope we will have native components that look more modern, support light and dark mode, and the api allows to be styled better. For example the input select, date picker, checkbox, radio buttons. Those are all really annoying to be styled.
Yup, there are two things websites which you guys like to call Web apps or some of you call them apps. Anything running from the browser is a website regardless of what type of website it is. Even if you’re running logic on the back end, it’s a website on a browser. Native Apps now that’s a different beast, that need better UIs or the ability to js and css directly on them. Then we have the fact that many libraries make end products look like clones, which happens by default because rarely do we have a new component we haven’t seen. UI for Native APPs or better css support without stacking frameworks.
UI Libraries are not dying, you're using Remix under the hood for the complex components. The change is that headless components are a trend now because opinionated customization is not on trend. It's just a matter of time before a company launches a new "material design" just like in 2014 and boom a whole new set of UI libraries emerges.
I do appreciate the fact that videos like this start debate and allow for a more specific and rich advice exchange (of sorts), but, I can't help but be annoyed at the fact that youtubers like him use plenty of clickbait-y titles making you think there is an actual revolutionary way of developing better and much more nicer web apps (sadly, on top of the mess that javascript is today), when in reality it's, more often than not, a stretched monologue on them being entitled to their opinions, telling you it's the best, the most efficient, the all-time-killer way of doing things, under titles such as "you need to start using bla bla RIGHT NOW", "this bla bla is the worst, try this...", and I'm not saying it's wrong to come up with an opinion and put it out in the internet, but I swear every webdev video or python video is just rant on people trying to code their way, and it feels kind of disheartening. Can we, for a second. just acknowledge, that the web is a mess and no cool component ui library or syntactical-sugar-feeding framework will fix it? I'm not an all time web developer, but I've been for a while now and even inside my team I can see them being entitled on whether Prime Ng or Angular Material is the best... idk, not really going anywhere, I just needed to vent a little 'cause, despite having so many veterans out here, I feel like there is a lot of immaturity in the web community still, and it's pretty uncool
I initially opted for Shadcn UI in developing our laboratory management app, but unfortunately, I found it to be less than satisfactory. While it boasts an appealing aesthetic, I encountered numerous instances where I had to handle many aspects manually. My preference lies in leveraging a component library that is not just visually pleasing but also comes pre-equipped with almost everything I require, sparing me the need to build components from scratch.
After grappling with several challenges, I decided to integrate Mantine into our app. Mantine, with its comprehensive feature set, turned out to be the solution I was seeking. Now, I seamlessly combine Mantine with Tailwind, and the synergy has resulted in a remarkably positive development experience for our project.
Thanks I have a look at it and it is pretty cool. I think Shadcn-UI also satisfy my needs but I did need some adjustments because the underlying component they use are sometimes not adequate.
I've used bootstrap and material in the past, but although it was great getting started I usually ended up not using most of the library and also ended up overriding a lot I was using. Another thing I realized was that I actually needed very little CSS in the first place. So a couple of years ago I started a new project and decided to not use anything and just roll my own CSS from scratch. Not only did I end up with something incredibly lightweight, but I learned a lot in the process. With the use of some CSS variables I could also change the colors quite easily and so create themes for different clients.
It was simple, it was fast, and it's just basic CSS with no build step.
Did you use plain CSS or modified it with SCSS ?
That's the perfect example how to NOT use bootstrap...
That way its sure way easier then rebuilding the whole needed css by yourself... cause who wants to have some extra work to make the own code look clean...
I used Bootstrap, MaterialUI and a bunch of other stuff... and NEVER ever had i touched the bootstrap stuff... i wrote my own shit or i used what i got there...
But changing Bootstrap Stuff or Library Stuff always sticks you to that specific version... and i hate everyone that make me fiddle that shit out later....
Its a mere horror to do so cause sometime somewhere need to split this shit again...
in a nutshell, you will spend more time and making your project more complex. just go back to native CSS, you will get things done faster and easier.
i have a great time with Shadcn, unlike other UI libraries, IT EASILY expands and modifies the components, and it sits perfectly in the middle. It is easily modifiable like tailwinds but also has a great just-get-go component like MUI.
The only gripe is when you tried modified the underlying radix part, but that's kinda my problem not the shadcn itself
For me, the operative takeaway is around 5:35 - "if you are building a component library for your company". Therein lies the conundrum. Not everyone makes or needs custom component libraries. Also, when you are operating in an environment where the most precious resource is developer time, having a "*all* batteries included" library that covers, oh, let's say, 80-85ish % of the project needs, is much *much* more important than wasting precious dev time to implement "oh this little tiny funny thing that we imagined" - and it should be a product / project manager's role to tell to the customer "no son, we will implement it in such and such manner, you want fantastic beasts and find them too, the budget must be quadrupled".
In other words: I like what I see but it's resource (as in Human Resource) heavy.
I love the concept, but i don't seen this working at enterprise companies out in the real job market. To me, design systems built with web components make the most sense at large scale. Big companies typically have multiple, silo'd teams, but upper management always wants a consistent UI across all products. Since most product teams at enterprise companies ive worked at have significantly different tech stacks, it would be impossible to align on using react only. Web components really shine as UI libraries in my opinion and they're only getting better
design systems will stay. you need components. it's a good experience. shadcn covers what brad frost calls recipes
@@jonnielappen5916 yep for sure. UI's that are composed up of smaller components. We create recipes as stackblitz examples where I work and have had a lot of success with them.
react/vue/angular is heavily used across all tech/fintech companies
@@utkarshraj1642 yup, where I work all 3 are used across 60+ products. Maintaining a framework specific component library is 3x the work and completely unnecessary. That's why we decided to build our UI components as web components and we have framework specific wrappers to make them even more seamless
If the engineering team exercising more ownership over UI code means the company as a whole exercises more ownership over the look and feel of the UI, this has the potential to be something great. I think a lot of teams tend to see "a good start" as "a good final product," but hopefully this style of UI library will help encourage teams to grow beyond square one.
didnt think this would just be an hidden advertisment video for a new technology :'D you got us viewers;)
I first using Bootstrap when I was using just plain HTML and CSS. But when I trying to starting to switch on react, I realized that it is more logical to built component by my self rather to relay on CSS framework. One more thing that some React UI problem is it's not gonna work on other framework using React. Lets say Headless UI doesn't run on next because of webpack.
Every couple of months I came back to watch a new Theo video, and every time the whole front-end ecosystem is dying and being reborn into something that will die in another couple of months.
It's tiring
how is this glorified copy-pasting better?
updating will be much harder than running npm update, especially if we make big changes to the original component and then have to merge them
I understand having more control is needed sometimes, but most of the time, I want to be abstracted away from library code
we need libraries that have both options:
1. they are npm installable
2. they have a copy source button (for the rare cases when I want to change the component source significantly)
A component library, especially when battle tested like Radix, will require much less update than customizations, so copy paste it's a good tradeoff IMO
"updating will be much harder than running npm update, especially if we make big changes to the original component and then have to merge them" -- if you make big changes to the original component, why would you be interested in updating that component from source again if you had to heavily modify it in the first place? It means you didn't really need the original implementation as it was.
These copy-paste libraries are used as a good starting point that you can take almost full control over and are not at the mercy of the maintainers of the project to implement something and you can adjust them and do your own additional UX if that's needed.
@2:06 Nice to see tailwind code in practice instead of some small tailored piece of code. How is this tailwind code any better than separate CSS?
Thank you. That’s what I’m saying, sometimes stacking classes becomes longer than typing the raw CSS, and if you been around you should have some classes that are used a lot. Is there native support for tailwind ? Or what makes it such a go to?
That's the best part, it isn't.
I believe the main purpose of tailwind / windi / unocss is to eliminate the necessity for class naming for css
The only minor thing that I don't like about shadcn/ui is that the style is a bit too tech-ish by being so minimal and requires some work to make the style fit to a less tech corporate aesthetic. But I guess with time they will add enought customization options for this kind of requirement.
Isn't the whole point that it's unstyled/neutrally styled and you style it according to your brand? I hate presets, they never fit the brand, and customization is mostly done through super basic css, most of which is inherited anyways
@@readywhen yes, what I am saying is that if the branding is not going towards a tech aesthetic, as it is, you will need to do quite some work to adjust it and I wish there was an easy way to adjust it, don't care about presets at all
I have only watched through like halfway, but thank freaking god you showed this to me, my biggest pain point was the fact that very often I get asked to use a ui library for a project and get asked to create things that aren't working well with the UI library, or change stuff that you can't really just change it, you can in the ugly way, and I hated the freaking shadow elements always because it just pisses me off, hard to deal with and modify it because you aren't supposed to modify it, this makes that pain go away, in my recent times I was so mad I completely dropped UI libraries because what I want simply just isn't inside that library or is in but in a different way, so I have to rewrite it anyways then why not just do it from scratch because in all fairness, it isn't hard to rewrite especially if I already use a framework and use those tools with it and not the native JS ones.
Is there a version that doesn't use tailwind? Css is a mess, and i don't want that mess in my ts files; it needs to stay where it should: in css.
"css is a mess" that's why I use tailwind tbh
Great video. From my perspective as a designer, I think this approach might make the design system turn into Frankenstein's monster really quick. At least you've brought AI into the discussion, which Vercel is really cooking up some cool stuff there with that component generator. I'm very curious how designers work into the fold with your approach, as I'm currently investigating whether to "go safe" with MUI recommendation for my PaaS client or instead assist them with building their own UI library with these newer frameworks like Radix along with Vercel's component generator. All I know is Tailwind CSS is super hot right now along with Framer Motion. NextUI is up and coming, but I like the idea of starting with basic components from Radix with zero design bias, whereas MUI introduces a lot of design bias with their Figma file. Don't get me started on MUI's [puke] icon library. Anywho, thanks so much for your bold perspective. People need that to get their head into AI these days. I'm curious to see what Google comes up with Gemini + Material Design. Very curious.
UI libraries aren't dying, we just have more options now. Theo, you saying that something is dying as a technology is kind of misleading, but I do understand that clickbait is required these days. You are close to bleeding edge all the time and also in Twitter bubble most likely as many of us here are.
People have been saying for years that jQuery is dead, but it's still probably in 50% of top 10000 sites and has like 8 million weekly downloads on NPM. This is for a library that is probably mostly still included as a CDN link and not installed through npm. Reality is just different compared to our bubble.
Predicting what front end libraries will die or will become popular feels like astrology for nerds.
I like learning all these new things, and shadcn/ui loos great, but I bet I’ll still be running into bootstrap or material up for a while to come.
Recently started a new project at work and went with Radix and StyleX from the bottom. Been loving it so far!
I am sorry I failed to understand the difference between installing radix or a component from another component library.
Don't get me wrong I love radix and how easy it is to use and transform to fit the design.
But saying we are no longer installing component libraries instead we are installing radix, this is the part I don't understandd.
It's just lower level, and otherwise jist an abuse of language to say you're not uaing a UI library anymore.
It’s a kinda sorta but not really solution. Coincidentally a radix problem was what I initially ran into, I believe it was the carousel. Keep in mind I installed a fresh react just to test shadcn, followed the instructions, had to watch a tutorial by an end user to get it to work, which included some tweaks not in the tutorial. Personally I keep asking myself should I just code it from scratch because this is more about fixing breaks that coding. The idea is good but they don’t flow at fast speeds. AI can now generate the js, and backend. OK time to try another UI then watch it break and have to break my head to make one button sample work. Then on to the next UI I must test them all. I’m UI greedy! It’s an illusion for the most part, of feeling like you’re up to date, but rarely is a new component created.
i kinda understand the benefits, but lets take daisyui for comparison. all daisy does is provide classes that are using tailwind classes. therefore i can use daisy default and then a little of my tailwind to customize and i still have it in its own component and i can fully customize it. no?
I'm starting to learn Bootstrap. It seems to be alive and well.
yeah, do'n't listen to some bs that is just to attract views and discussion. Stick with proven and popular tech - Bootstrap, maybe React later
@@lechproteanTheo is a junior to me. I just occasionally watch for inspiration. I have already worked with React for a few years, but never really got into CSS.
If you are just starting out, this discussion is not for you!
@@eamax Why?
@@31redorange08, you need to learn at least something before you can understand what is good for you
That's just a worse fork. We should instead have a CLI that automatically forks a package and set it up locally in your project. Then you'd be able to pull changes as the package update, while keeping your changes
*Summary*
* *(**0:00**)* *UI Libraries like Material UI and Bootstrap are becoming less popular.* The video argues that they are "dying."
* *(**0:26**)* *The future is shifting towards building custom component libraries or leveraging tools that generate component code directly into your project.* This gives developers more control and avoids the limitations of pre-built libraries.
* *(**0:56**)* *Shadcn/ui and Tailwind UI are leading this shift.* These tools provide pre-built components and the infrastructure to create custom ones. Instead of installing a whole library, you copy the code you need into your project.
* *(**4:56**)* *This approach offers a balance between the speed of using a UI library and the flexibility of building everything from scratch.* You can start with pre-made components and easily customize them.
* *(**5:56**)* *Tools like Vercel's v0 (VD) use AI to generate component code based on your descriptions, further simplifying the process.*
* *(**10:55**)* *This shift is enabled by underlying technologies like Radix UI and Headless UI, which provide accessible, unstyled UI components.* This lets developers focus on styling and functionality.
* *(**12:45**)* *Ultimately, the video argues that this new approach will lead to more accessible, customized, and maintainable user interfaces.*
In essence, the video suggests a paradigm shift in how front-end developers build UIs, moving away from bulky, opinionated UI libraries to a more modular and customizable approach that emphasizes individual project needs.
Summarized by AI model: gemini-1.5-pro-exp-0801
Cost (if I didn't use the free tier): $0.0637
Input tokens: 16335
Output tokens: 619
I wish you’d talk about Chakra UI sometime. It has a ton of features that scale from small to large projects. Everything any other lib can do, Chakra can also do. You can make your own component library with it as well.
Chakra can’t avoid having a runtime. That’s why they built Panda to replace it. Also, Chakra doesn’t work crossplatform (React Native plus web). But Tamagui can.
He has talked about Chakra before th-cam.com/video/CQuTF-bkOgc/w-d-xo.html
Great video, thanks for the amazing content. I'm learning so much from you!
I feel like we are just running around in circles and reinventing wheels just to satisfy some urge to invent stuff.
Component libraries are fine and they are not dying, they are actually very popular. And most importantly, they save A LOT of time and money.
Yes and no. AI now gets you to point B faster than attempting to learn framework languages and fixing breaks in the code. The next level is no code. A GUI build of the visual. With AI working on state and logic. Obviously people will use what they know. We run around testing every UI to render one component. Then go test the next library. The bottom line is , is the new generation of coders willing to learn the whole framework and the frameworks mini language to get up to speed. When AI can guide them in one or two days and build the code from scratch saving so much resources by not loading so much unused code.
They save time and money in some cases but not in others. Writing code doesn’t take that long if you know what you are doing. These libraries definitely do not save time if you want to do something that they make very difficult. In those cases, you wished you just built it all from scratch.
I would really like to know what practical stuff can you make with any of your tools that I'm not able with pug+bootstrap.
I've been asking around for some time, but haven't got any answers worth a second thought
I wouldn't use anything else than my skills and writing CSS and Typescript. I see no point in this !
It’s been far too long since I’ve seen you. I’m so glad to see your work again.
"UI Libraries Are Dying"
*proceeds to show UI library*
Tailwind has a build file that you can customize. We technically build a style element into html blocks, containing just the styling for that component. Gets triggered whenever I save an html file in that directory. But its nice that I can just alter that, if I have to.
the big problem with shadcn/ui is that I cannot use it since I do not use tailwind, so I'd have to recreate styles myself and at that point I might as well just stick to Radix
I think it's good. I'm a new developer who learnt UI with Bootstrap. But few things that have always irked me with it is that I get a bunch of components I don't need in my applications and it can be sometimes clumsy to do your custom component styling. Seems like this is a much lighter and flexible method for future UI.
Hi Theo, As a preface for my comment. I'd like to mention that I don't particularly agree with a lot of your viewpoints (especially around backend) but I do respect your insights as a developer. My experience is coming from the background of a primarily backend developer and entrepreneur that believes in low to no dependencies, and emphasizing unique user interfaces that correspond to the businesses unique branding.
You're take on user interfaces is accurate in the sense that it'd better to have a UI within the application itself instead of a library (actually reminds me of a internal cli tool I made to embed my atomic design into any application directly so I could modify it as necessary in a way that's inline with that unique application.)
Basically the current issue with component libraries is when you want to customize the look, it becomes very complex to do and you need to modify the code within node_modules which isn't optimal in any way.
What I don't agree with is your take on shade. Personally I don't like it and have no interest in using it. While this does partially come from my unwillingness to use anything vercel (which is basically just a company that took over the primary usage of the react framework and added a Bunch of things to it to make developers lives "easier" and I'm sure they do but in reality most of what they make is just a giant dependency tying you to this company and that's exactly what they want $$$)
Shade provides these pieces of functionality that you mentioned are a pain to make. And I can tell you they are. But the issue is that shouldn't matter. As developers we should have knowledge of the entire E2E codebase. Meaning we can build the ui, the frontend, the backend, the infra, the database, etc. I don't believe in segmentation of responsibilities because then you're in trouble when that knowledgable person leaves. Instead as developers we should be able to build the entire stack end to end. I'm not saying you need to build your own http library but most of the code should be your own.
Where this intersects in UI is the (just use this libraries functionality) aspect. UI is complex and by just using these components without internal knowledge of how they work you'll inevitably come to the point of (damn I need to read all this code I didn't write). Instead I propose a "creating your own shite approach". Meaning if I'm working for company X, company X has a unique way that they want to be perceived by the world. Instead of trying to retrofit these libraries created for other companies use cases (or as a way to add a dependency between you and a company) look to your client you should be creating a unique ui system for company X with matching style guides. The atomic components that are created for company X should be contained within a storybook application that's separate from all other applications for easy reference.
I then attach this to my cli app and have developers just run the cli to embed the atomic design into their application.
So I don't have to repeatedly create the same functionality over and over I just have an internal (to me) library that contains all the different components that I would use in a typical application. Essentially my own component library. From this I can just pull the code I've already written over, modify the style of it to match them, add it to storybook and done.
The best part is I understand all the code I produce. Fully. With corresponding documentation all in the storybook app.
I think it would be nice to have a native way to customize the look and feel of the checkboxes and select field. I really gussed by the title of the video that it would be something on this direction :(. Other than that I don't see those UI frameworks dying, I would say that we can maybe see they migrating to this same path.
When it comes to stylable select fields and checkboxes, I hope the work that the people behind open-ui do eventually comes to life
That’s… that’s just CSS.
Like… literally. That’s what CSS is for.
1:47 Yeah this seems way easier /s
should have just titled this "tailwind more popular than bootstrap?" it's pretty obvious what you'r doing there 1:02
So, why in the docs do they not say that this is a React components? I hate it when libraries assume everyone uses React. No, there is a sane world out there that doesn't use React.
pls stop shilling for vercel
Let's hope your comment will not be deleted.
I remember fighting with Bootstrap so many times because it did only 90% of what we wanted while we didn't need 50% of its features, and the remaining 10% were almost impossible to add in a meaningful way. I ripped Bootstrap out of multiple projects to build a custom UI library. This approach is much better! I really have to look more into Radix and Headless UI! Shadcn/ui also looks great, but we are not using Tailwind and personally I'm also not 100% sold on it. I prefer writing CSS to get full access to all its features, e. g. custom properties, container queries etc.
Now that scoped CSS is right around the corner, I'm wondering what else will emerge or how we'll adapt existing tools.
5:00: v0 doesn't seem to work. They want a phone number and then reject when I give it (not USA)
ironic, how the title says "ui libraries are dying" and in the video you are using just another UI libraries.
I suggest reporting the video as "misleading text".
I have always been avoiding libraries whenever i wanted a quick webpage to test things.
Just staying with plain HTML/CSS/JS.
Now is the best time for this, because you should know how to make tweets and know your terms to have AI assist you in coding heavy js logic. HTML and css is simple. Goes further and databases are now easy too.
Yep, I'm just catching up from 7 years out of the industry, and I'm back to full circle today:
- writing my own libraries in vanilla and/or TS to cope with types, and basic things like ranges and number epsilon stuff.
- figuring out what primitives I can/can't have that are compatible broadly from MDN, like I can't use DOMMatrix yet, but transform is on the table.
- eslint, but I'm going with stylistic and abandoning prettier.
- abandoning vite and vitest because files that are scrambled and named adslhsetg aren't okay.
- back to es6 module imports without @s.
I *am* using JSX because it allows me to write stuff declarative *slightly* better than using template strings, but I'm open to hearing things.
I hate all of this.
I think we should rethink web as a whole.
I like the idea of CDN's but we all know they're unreliable. I also think that having to "npm" libraries is one of the dumbest things ever. Why hasn't a solution come out where you can simply download a "library" into each of your project folders? "npm"ing to me is like requiring machines that run Java applications to have Java running on their machines.
Do you want your MacOS code or Windows code in your project as well? Ever heard of open/close principle? We want to use a good to go component that can be configured with a small manageable number of parameters. That's it. We don't want to look into its UGLY code inside (or pretty).
This has an amazing educational value as you can see how good component are written
No, they're not dying. Frontend devs are just in a bubble with React, Tailwind and all these complicated things. Bootstrap will never die for backend devs. They know what I'm saying.
I have a friend that claims we went to this hyper complex front end being separated from the backend was in order to make engineers more "plug and play" in service to capital. So your engineers were basically disposable cogs.
I used and loved, but faced an downside if the component have some bug is hard to follow the fix
Haven't done much react yet, I've been helping a friend with their project where they are mainly using Vue. I'm relatively new to the whole component UI structure and can see the benefit that it's more templated components that get created. Helpful video, and understand your point of view.
I haven't used any such library at length, but i did a couple prototypes with vue and it was nice.
shadcn/ui is basically just a "code snippets" collection
If the shadcn/ui devs improve one of their components, how do you bring these improvements into your own (possibly modified) codebase? Just go through the changes one by one and copy-paste?
Yeah this seems like the biggest thing to me. How do you "upgrade" a component made like this? Whether for new features or bug fixes?
We struggle to deal with the tradeoff of of having perfectly working UI from libraries and them being too hard to customize, so end up building a lot of components from scratch
This seems like a good compromise
Is there something like this for angular as well? Or is it already built in a way that it can be used from any framework?
If you go to the documentation you'll see there are some frameworks supported via the cli method and you can make the manual installation too (don't know if this makes angular compatible though)
@@awol2 I believe the original shadcn/ui works for jsx/tsx, so frameworks like Angular, Vue or Svelte aren't supported by the original shadcn/ui, but there are heavily inspired implementations for these frameworks: Angular has spartan/ui, Vue has shadcn/vue and Svelte has shadcn-svelte. I don't know if the original creators of shadcn/ui are involved with these, but they look just as good,. though I haven't worked with any of them.
maybe maybe.
I'm not against this pattern at all for some use cases.
I really like the trend of moving towards prioritising simpler codebases with less deps instead of large deps with large wrapper code to make use of it.
It always ends up being the devs that add stuff thats too complex and not being ruthless about cutting fat of apps they build.
Then you're not cut out for the fabulous world of modern front end! Where literally everything is just mind numbing, bug-ridden configuration! If you want to actually engineer anything, you'll have to make your own framework for the app builders to spend all day trying to configure :)
100% yes I totally agree.
I'd be willing to bet bootstrap will far outlive shadcn ui. Don't get me wrong, I think shadcn and radix are cool and I think unstyled components are a great pattern, but the web is larger than React and sometimes you don't want/need to build your own design system from scratch
Been doing front-end dev for 14 years and rarely used UI libraries.
If you make your components git submodules you can still version, pin and update them in a central place if you want to reuse them across many projects
I wish combobox was for “selecting multiple things at the same time” though. Had to implement my own thing with Command and popover
What are your thoughts on react aria components from Adobe?
This might be a trend. This might solve extreme use cades. I don’t eanna go into this direction with a product that is not a component library on its own.
I think I'm in agreement with this. I much prefer this way of owning the code for your components. It also helps down the line when you have a project that goes into maintenance mode and then someone comes back to your code a few years later to "add a thing" and now your dependencies are out of date and it can rapidly get messy. So I think this helps with future-proofing your code.
It is not future-proofing if you are full with outdated dependencies, it just means your project is using several packages with known vulnerabilities.
Big upvote from me. This game me a lot of useful tools to use. I've never been sold on the traditional component libraries and enjoy having full control over the component myself and would spend time recreating components just to have them in my project and be fully curated by me. I love this approach and will be adopting this.
for me working with backend and front end for more than 15yrs, I would still stick with Bootstrap and manual CSS, You can easily solve any issue with complex PSD design/layout to CSS/HTML if you have the knowledge and understanding the core code of CSS.
Before, I didn't want to use component libraries, but I didn't know how to express why. However, the first time I used Shadcn, I understood.
What do you think about Next UI? I love using so much
Agree!