It took me almost two weeks to finally understand my tailwind components were not working. THANK YOU SO MUCH FOR THIS.
@interceptorghost11494 ай бұрын
This video makes me level up my software engineering knowledge, nice video
@Merchance3 жыл бұрын
Would be the best series if you also integrate Storybook to the workspace
@DioArsya3 жыл бұрын
yup
@gno39392 жыл бұрын
yup
@justinoneill28372 жыл бұрын
yuppp! and *SVELTE* !
@ryskin822 жыл бұрын
thats I wanted to write too
@sweetwarmblanket3 жыл бұрын
Hey Leo, I recently found you ( last month ) while looking for videos on GraphQL and your videos on GraphQL microservices and fedeartion are really amazing, I've learned a lot from it and has subscribed since the first day. I had seen your others videos and the monorepo one as well but this is something I was wanting to explore with a backend and frontend, sharing different module/plugins/husky commands using monorepo. I have learned everything from the internet and watching countless youtube videos from people like you and I really appreciate the work that you guys put in but I haven't seen a single video where someone has shown the entire procress from scratch to deploying a app ( FullStack app ) with all the industry standards. Things like, a scaleble backend and frontend fueled with typescript and graphql with proper authentication ( using cloud functions if needed ). Setting up CI/CD, docker, cloud for deployment ( AWS/Serverless ). It's a request if you could put out a video covering and explaing everything from start to finish of a FullStack ( doesn't have to be a complex a simple one like router protection with backend validation or something like that ) that'd be really helpful. Thanks again, I really appreciate your work and hope you grow to be a successful KZbinr. P.S. Happy Holidays
@CodeDunks3 жыл бұрын
Hey R, I appreciate this message a lot! Really nice to know that my content has been able to help out. I am currently working on a full-stack course that will cover from the beginning of a project to deployment right now. I hope to have it out here soon but it is just taking a little bit of time between work, holidays, and other projects! Good luck with everything.
@sweetwarmblanket3 жыл бұрын
@@CodeDunks I appreciate the quick reply :) and yeah, I can completely understand, time management between work and your other hustles especially during this time of the year can be really difficult at times but I'm really looking forward to it. Take care and stay up!
@rudrava2 жыл бұрын
bruh u saved so much of my reading time ... best intro out there Love
@workflowinmind2 жыл бұрын
If you've seen your watch time increase recently it might be me... I watched the whole channel! Keep it up
@musbell3 жыл бұрын
Thanks Leo. Looking forward for the next video.
@gregederer69453 жыл бұрын
This is exactly what I was looking for. Thanks!
@Feetsha2 жыл бұрын
Your content is one of the best out there ngl ! Keep up the amazing work
@milad84362 жыл бұрын
The course I was looking for. Exactly the one I wanted
@meysam02132 жыл бұрын
tnx leo this is best practice for develop frontend monorepo,
@vedantbothikar2 жыл бұрын
Thanks for this video man!
@NOBOKSify3 жыл бұрын
literally saved my life - thank you so much!
@quyetnguyen91613 жыл бұрын
This is awesome, thank you. Can't wait for the next video.
@footballrecap1631 Жыл бұрын
nice one man, this was really helpful
@NotAllHeroesWearCapes-1013 жыл бұрын
this is super awesome .. waiting for the next part ..:)
@taghavi_script5 ай бұрын
thanks man, i enjoyed
@andrewkorin3 жыл бұрын
Good stuff. Keep going! Liked. Subscribed. Waiting for the next part.
@alex94712 жыл бұрын
You mean the next next part
@_kadirmetin8 күн бұрын
Thanks for the video 🙏
@marcellciszekdruzynski2 жыл бұрын
Really nice, thanks for this one !!
@b1chler3 жыл бұрын
Cool man! Thanks for the intro!
@williamliu7962 жыл бұрын
Thanks so much for this video. I went absolutely nuts trying to figure out why my tailwind styles werent working through the UI library. They were being purged!!!
@codernerd70763 жыл бұрын
Never heard of this sounds good!
@curiousprogrammer90 Жыл бұрын
Very nice and good explanations! Thanks! :)
@muratasarslan23592 жыл бұрын
Very clear & helpful. Thank you Leo 🙂
@mateh32732 жыл бұрын
You’re the best man
@binov50122 жыл бұрын
Excellent! Thanks 🙏
@sirawichvoungchuy31283 жыл бұрын
Storybook integration would be great thank you!!
@doobtom2712 жыл бұрын
Your Christmas hat still applies at the time I watch this video, lol
@juanzapatagomez80642 жыл бұрын
By any chance could you make a tutorial on adding Prisma as a package?
@sokhuonguon92512 жыл бұрын
really really good
@7iomka3 жыл бұрын
Storybook integration (at least for UI components) please! Subscribed!
@cesarpintos84183 жыл бұрын
Thank you a lot christopher mintz plasse
@CodeDunks3 жыл бұрын
😂😂😂
@bridlershoc65693 жыл бұрын
Hey great video, shared it with people! When will you release part 2?
@CodeDunks3 жыл бұрын
Hey there and thanks! I plan to release it sometime next week. Was just gone for the hoildays visiting family.
@PartneredAdmin5 ай бұрын
Hi how to add a new app using a command e.g. npx create-payload-app@latest as an app to a turborepo? I can 't find this anywhere clearly? So...is it just delete the node_modules and copy/move all the new app files to /apps and add name and version to the workspaces?
@fooked12 жыл бұрын
May I ask, why did you include the same dependencies in both next package.json files? Wouldn't it be better to move those deps to a common package.json -- perhaps the root package.json?
@alexandardimcevski9136 Жыл бұрын
How do we add Font to the UI package and the Apps?
@MrEnsiferum773 жыл бұрын
Is it possible to remove deps and devDeps from packages and apps folder, and reuse what u can reuse from root package.json file, like typescript, react, react-dom and turrbo repo on build step to find all root depedencies?
@CodeDunks3 жыл бұрын
I believe that you should be able to reuse devDependencies, removing dependencies however might be a little bit more complicated. I found this interesting issue on the Lerna repo that might explain github.com/lerna/lerna/issues/1079. I haven't had to do this with turborepo yet so I am not 100% sure.
@MrEnsiferum773 жыл бұрын
@@CodeDunks I've managed to solve with shared dependencies like react, react-dom installed in packages/shared, and shared imported in apps/remix as "shared": "workspace:*, because I'm using pnpm... Now I have issue with finding every devDeps binary except eslint, like rimraf. Packages exists inside apps/remix node_modules folder, and I can see them as symlinks, but for some reason, is not working recursively. Opened discussion for help on github.
@CodeDunks3 жыл бұрын
@@MrEnsiferum77 sounds like quite the setup, could you link the issue so I can follow as well? Got me interested
@MrEnsiferum773 жыл бұрын
@@CodeDunks That eslint command, gets me tricky. Some other package from remix or directly remix isntalling eslint binary, that's why its is found. The problem is with pnpm, which is not possible to have subfolder dependencies and to be found upstream as binaries. U need to installed all of them in root package.json. I still trying to figure it our if monorepos tools or npm/yarn/pnpm can make binaries avaiabled installed in one packaged, into another one, which imports it. I'm planing to make turborepo monorepo with multiple techonologies as template, so probably when I'm done will be part of turborepo templates.
@CodeDunks3 жыл бұрын
@@MrEnsiferum77 Hmm interesting, I haven't had a chance to use pnpm yet but hope to get to it soon. Appreciate all the information and look forward to that repo once you have it done!
@abdullahclementabdulshekur6736 Жыл бұрын
can this set up be used to build microservices
@sourav_-_70382 жыл бұрын
instead of next-app and next-next-app can you use mf-proj1 and mf-proj2
@martinlupa8692 Жыл бұрын
Hi Leo, great material. I am setting up a monorepo for a side project and this video helped me a lot to understand the shared configurations between projects. I have a question that I couldn't answer yet. When setting up the shared eslint config, why is it important to let "prettier" to the last in the extends array inside eslint-next.js? I have come across other projects that do not respect that ordering and was wondering why. Thanks a lot!
@CodeDunks Жыл бұрын
Hey Martin! Thanks for the kind words, from my understanding eslint applies configurations sequentially. Since prettier is pretty opinionated formatter, it can conflict with your other ESLint rules, putting it at the end ensures that prettier always "wins" and formats your code
@martinlupa8692 Жыл бұрын
@@CodeDunks thanks again!
@lukafireman2 жыл бұрын
Hey man, Awesome content!! Mind sharing details about your workspace setup? What you use to set up your Workspaces, VSCODE, OS, Extensions, etc. Including that lovely terminal of yours.
@hakanaki2 жыл бұрын
Why can't Turborepo packages work with plane React 😥😥?
@alexand2153 жыл бұрын
thank you so much
@lamogura2 жыл бұрын
I am curious what you would do if you are using a tailwind plugin or extending the theme etc only on the UI components? Or vice-versa? Would that still all work as expected? It seems only autocomplete etc is playing nice because you copy/pasted the same config to both places. The approach is different than how you did tsconfig, so I guess there isnt a way to put all the tailwind config in 1 place and share?
@CodeDunks2 жыл бұрын
I think you are asking about whether you could have a shared config? I found this article that might help tinypixel.dev/use-yarn-workspaces-to-share-a-tailwind-config-file-throughout-your-wordpress-application/
@Jamie-kf2vf3 жыл бұрын
Question; I have a Nextjs app currently (not a monorepo). If I create a Turborepo monorepo, could I just drag my NextJS project into the apps/ directory? It already has all the eslint and prettier config.
@SivakD3 жыл бұрын
Hey. Very nice video. I've been using this tool too and it seems good. Do you know if there's a way to specify a build order for apps that might depend on packages in the package folder? (e.g. if app A needs package A, it has to build that package before trying to build app A) Is it the pipelining or just the order of the build scripts? Thanks in advance.
@CodeDunks3 жыл бұрын
Yeah I believe you should be able to use the "dependsOn" pipeline configuration specificPackageTasks. So like you could do something like in "pipeline" "appA#build": { "dependsOn": ["packageA#Build"] } Check it out here turborepo.org/docs/features/pipelines
@SivakD3 жыл бұрын
@@CodeDunks Thanks for the reply. I was playing with it some and the pipeline is definitely the way to go as well as having dependencies defined in the app's package.json itself. I'm new to monorepos but I am liking this tool thus far.
@meysam02132 жыл бұрын
how to integrate storybook with this ?
@lcui48133 жыл бұрын
nice video! do you know how to make vscode autoimport working in this video's monorepo? now i need to manually import once then it works
@CodeDunks3 жыл бұрын
Hmm I don't think I have ever used that extension unfortunately
@ngoclam98242 Жыл бұрын
sorry but can you explaint, why we use "./../packages/ui/**/*.{ts,tsx}" not "./packages/ui/**/*.{ts,tsx}"
@ishanagarwal34642 жыл бұрын
Great video, I am very new to this, could you please tell advantages of turborepo over simple monorepo? Any is sharing ts config possible without turborepo?
@LarsRyeJeppesen Жыл бұрын
Caching. If you want more advanced stuff, go with NX which is superior but more advanced/complex
@siya.abc1232 жыл бұрын
Great tutorial thank you. But, so many configs are intimidating
@hirisraharjo2 жыл бұрын
How to do it without tailwind? (ex: purgecss only) Anyway great video as usual!
@LarsRyeJeppesen Жыл бұрын
I really hate how TurboRepo is so associated with NextJS. It is like they try to force to use that all the time. It would have been nice if you didn't set it up with the default NextJS, because anyone not using it cannot use the same approach as you did.
@dimitrisefstathiadis65622 жыл бұрын
Your root commands should run yarn workspaces lint, and then run it for all packages. What you are doing there while correct is not reproducible..
@jamielee44272 жыл бұрын
Well this is simply brilliant! Thanks man. Btw, just to point out, prettier doesn't format on save for me unless I create a .vscode/settings.json and have the following config: { "editor.formatOnSave": true, "editor.codeActionsOnSave": { "source.fixAll.eslint": true, "source.organizeImports": true } } This is fine, but more for those who aren't aware. I had a Next project with this set up but the Turborepo one didn't. Question - when I save a file, will it apply the correct prettier configuration? (say, you have one in next-app which is different to next-next-app).
@CodeDunks2 жыл бұрын
Thanks Jamie! You could also add those settings to your overall VSCode settings I believe so it doesn't need to be per project basis. 1. CTRL + Shift + P -> Type settings and open Settings (JSON) 2. Paste "editor.formatOnSave": true, "eslint.format.enable": true, "editor.defaultFormatter": "esbenp.prettier-vscode", "editor.codeActionsOnSave": { "source.fixAll.eslint": true }, "eslint.options": { "extensions": [".js", ".jsx", ".md", ".mdx", ".ts", ".tsx"] }, "eslint.validate": [ "javascript", "javascriptreact", "typescript", "typescriptreact", "markdown", "mdx" ], That is what I have in my settings (JSON), might work for you. Sorry if it doesn't haha
@omkarkulkarni36443 жыл бұрын
eslint not working unfortunately
@CodeDunks3 жыл бұрын
What seems to be the issue?
@shashwatgupta99932 жыл бұрын
Same... did you find any solution?
@shashwatgupta99932 жыл бұрын
@@CodeDunks getting this error but don't know how to solve it. Could not find a declaration file for module 'config/eslint-next.js'. '/Users/shashwat/Desktop/Turborepo/turborepo tailwind with jit-mode/packages/config/eslint-next.js' implicitly has an 'any' type. Try `npm i --save-dev @types/config` if it exists or add a new declaration (.d.ts) file containing `declare module 'config/eslint-next.js';`
@shashwatgupta99932 жыл бұрын
it works on putting noimplicitany to false but i want strict type checking
@CodeDunks2 жыл бұрын
@@shashwatgupta9993I ran into the same issue where the linting was actually not linting anything. I've updated the repository with a version that should be working. github.com/leoroese/turborepo-tutorial
@fortunatmutunda41942 жыл бұрын
This is what you don't find in the offical docs.
@dimitrisefstathiadis65622 жыл бұрын
100% sure these configs are gonna change in v2 of turbo repo and will pivot to the way Nx has them. They confused themselves a bit and made the configs too complex.
@CodeDunks2 жыл бұрын
Yeah they've changed already lol. Turborepo now defaults to a turbo.json, if you happen to have an older version before that change, they also provide a command to update automatically to turbo.json
@dealerpriest2 жыл бұрын
The number of times you can skip saying the words "go ahead" is overwhelming. Those words are, in most part, just fluff😊
@markokraljevic1590 Жыл бұрын
you should talk slower, sounds like you are nervous
@peroconino2 жыл бұрын
Its pretty hard to find content about monorepos on the internet, this video helps a lot understanding how it works. But unfortunately the solutions may deprecate with time. I was following your steps to configure eslint (tsconfig worked just fine) and the part where you configure the import resolver seems not to be working anymore. But it actually got easier to do it. I didn't had to override parserOptions in eslint.js project level. I just had to pass to next-preset.js at settings>import/resolver>typescript a property called project and there specify the path to next project like this : project: ["./apps/next-app/tsconfig.json"]. And worked just fine to recognize the absolute paths from tsconfig. Hopefully this helps someone in the future with the same problem I had.