This guy makes complex stuff so simple. What a great skill to have!
@billynitrus2 жыл бұрын
He’s got a great voice, could go into voice acting if he gets tired of software
@LuckiestManAlive2 жыл бұрын
11:05 - Out of the entire tutorial, as useful as it is... This is what I value the most. Being able to share the excitement of getting something to work when I barely know anything about it. Don't ever lose this energy Jack!
@angelxv012 жыл бұрын
I really like how you teach different technologies and how excited you are to teach them. That’s really helping people getting involved! Keep up
@ogreeni2 жыл бұрын
I wanted to get started with tRPC, and the first thing I did was check if you’ve made a video about it.
@theyreMineralsMarie2 жыл бұрын
I love seeing that tRPC uses React Query. It deserves to be the standard for all React http requests.
@jedliu86712 жыл бұрын
Share the same opinion!
@pieter-venter2 жыл бұрын
I agree! We been using trpc for over a year now with Prisma and next and we're hiring. Hit me up on Twitter if you keen to join
@DanKaschel2 жыл бұрын
I watched half a dozen videos today on this topic and this is the first one where I understood how to use it and where its trade-offs are. Great tutorial.
@DavidWoodMusic2 жыл бұрын
A few weeks ago I said you had a knack for dropping videos on exactly what I'm looking for. And you've done it again!
@chengxiaoxia80462 жыл бұрын
Thanks Jack. You saved me so much time by demystify the whole process, from setting up the development environment to wrapping up the project. Clean and effective code.
@aaronmotacek93432 жыл бұрын
Ok a lot of awesome stuff, great examples, excited to discover you and subscribe, etc., but... that transition at 21:26! Had to back it up and rewatch that a couple times! Haha nice work
@b1n1yam2 жыл бұрын
One of the best decisions I've made is subscribing to this channel. This guy is awesome!
@griffith4882 жыл бұрын
Another fantastic video on new technology. Perhaps in pros/cons, on backend side trpc is only nodejs unlike REST, GraphQL, gRPC supported in most programming languages. Apologies if I missed that in the video. Really keen to try it out 🙂
@devwax2 жыл бұрын
Wow... how have I not heard of this channel until now? This is great. Thanks!
@optimus_gpt2 жыл бұрын
Great love it! Reminds me a bit of my WCF adventures back in the days where I could just import a wsdl file (versioned) on the client and I had the models and type safety setup within a breeze. ❤️ This comes really close. 👍🏻
@DanKaschel2 жыл бұрын
I do not have fond memories of wsdl. In general, a workflow that requires a bunch of code generation eventually runs into synchronization issues unless there's a lot of discipline (or it's just a single developer). Not saying it doesn't have its place (in C# I'm find of linq2db with T4 templating), but I think sharing types between client and server without code generation is better than wsdl. ...Well, after accounting for everything you lose by not being in a strongly typed environment.
@optimus_gpt2 жыл бұрын
@@DanKaschel yes exactly it is nice when there are not a lot of devs involved. It works nicely in rapid development cases.
@sreekar_s2 жыл бұрын
0:39 slick transition
@reemnourali40052 жыл бұрын
Cool stuff! Please keep making videos like these. Ps: The video quality is getting sooo much better these days.
@RedCrafter072 жыл бұрын
I didn't know anything about tRPC and this video explained it so well. Also, it wasn't boring at all. Thanks for the video!
@Ollinho122 жыл бұрын
Awesome stuff - been waiting for a good tPRC tutorial as I've seen a few devs use it
@simonflk2 жыл бұрын
Great video, nice and clear thanks ❤ I feel like you undersold the benefits of that e2e typesafety a bit 1 other downside to tRPC compared to REST/GraphQL/gRPC that you didn't mention is that unlike those others tRPC is only useful if both your FE & BE are TypeScript. Technically it probably also works with a JS frontend, but you'd lose the main benefit I'm really glad I stumbled on your channel, lots of great content I can share with team mates
@jherr2 жыл бұрын
I would say that tRPC is no worse than REST in that situation. gRPC is kind of a different story altogether because protos define everything and you can't get around the protos. GQL is different again in that there is runtime introspection, which neither REST nor tRPC (or gRPC) have. Anyway, I think tRPC is a no downsides upgrade on REST, but tRPC vs GQL or tRPC vs gRPC is a different story.
@codewithguillaume2 жыл бұрын
Thanks very interesting ! Really thinking about how it could compete with GQL ❤️
@armaandhanji71512 жыл бұрын
Hope you can make a video that shows a production example of using rabbitmq or queues in the wild with a react app. Thanks for the awesome content!
@michaelfaith2 жыл бұрын
Such a great walkthrough. Thank you!
@user-tz6nn8iw9m2 жыл бұрын
love your vscode theme and font
@breytex2 жыл бұрын
Thanks for the vid, @jack. You are my fav. channel for getting react ecosystem news :D When you make a video about it, its about time to put it on the radar.
@fev42 жыл бұрын
OOOKAY! Those transitions are cool
@petarkolev69282 жыл бұрын
Wow! Amazing video, Jack! Thank you so much ❤
@eaglebirdiepar2 жыл бұрын
These new transitions are 🔥
@FacterNerz2 жыл бұрын
What a cozy house I love that forest view
@tejasnikam32872 жыл бұрын
Thanks jack !!! All your efforts are priceless ❤️
@alastairtheduke2 жыл бұрын
Excellent and clearly explained. Trpc's advantage seems to be in its simplicity and speed in terms of design. As long as you're in a monorepo and are using typescript, I think it's a great option.
@dota2content755 Жыл бұрын
One of the best ways to build apis wow can't imagine takes all the work using traditional rest APIS
@MishinMachine2 жыл бұрын
Awesome and clear! Please make a tutorial of how to implement tRPC with nextjs 13 app directly
@wendanny6732 Жыл бұрын
Really awesome explanation
@NateGUMBC20 Жыл бұрын
great tutorial. thank you!
@mohammadmahdifarnia53582 жыл бұрын
Thanks for monorepo. I didn’t know how to link those without npm link command
@wagnermoreira7862 жыл бұрын
A-mazing content! I'm trying out the T3 stack and your video is incredibly helpful to understand trpc! question, shouldn't the onAdd query be auto invalidated because it suffered a mutation? I feel like forcing invalidation in the onSuccess callback shouldn't be necessary
@shubhamlatiyan79722 жыл бұрын
Thanks, Jack for the always awesome video. Can we get a video on utilizing the workers in browser to at the best extent possible to get performance.
@jherr2 жыл бұрын
Definitely thinking about that one.
@AlexandrosFotiadis2 жыл бұрын
I personally use apollo client with graphql, I have the same features but trpc is also really interesting.
@canghaocai45742 жыл бұрын
Thanks, Jack
@chris30792 жыл бұрын
I love you give the github repo. There is alot to like about the trpc, fresh, deno stack. So moving my stuff over. Keep running into small issues, like do i need a mono for trpc etc. Love more on this stack together. Also what scales better gql or trcp for request etc? Or should i just go server api. We always talk about developer happiness. But i want whats best for my consumer.
@jherr2 жыл бұрын
What scales best... Depends on what scales means to you. In terms of load I think tRPC scales better because the per-transaction costs aren't as high. IMHO, if you are offering API as as service, then go with GraphQL, if you are building both the server and the client, use tRPC.
@zomakaja2 жыл бұрын
You should check out Telefunc. It's similar to tRPC but has a more ergonomic api. IMHO
@DB-dk2mj2 жыл бұрын
Thanks a lot, man! You do great!
@amanueltigistu82682 жыл бұрын
Thanks Jack. It's a great video. One thing that I need to know is that tRPC can run at the Edge like in Cloudflare Workers, Deno Deploy, Fastly Compute@Edge, others... Recently I have started using Cloudflare Workers with Solid Start (The Awesome Solid.js Meta Framework) & Deno Deploy with Oak & Faunadb. as a result, the whole thing is fast. Building API's & SSR (with HTML Streaming) at the Edge is Really Awesome 👍😎.
@jherr2 жыл бұрын
I honestly don't know. You'd have to ask the tRPC author on that one. :)
@jasonthorpe34702 жыл бұрын
Great video as always! I learned something new every time and trpc is so cool! I've always found sharing types with the front and back end such a pain. Not to pick nits though: isn't it the browser that enforces CORS? That's a security mechanism that always mystified me...
@jherr2 жыл бұрын
Yeah, CORS is only required for CSR.
@DanKaschel2 жыл бұрын
The browser enforces requirements established by the API. CORS is the mechanism that allows an API to say it's okay with requests from other origins.
@jasonthorpe34702 жыл бұрын
@@DanKaschel I wasn't really confused by how it worked, just that it's so easy to write a proxy that enforces a different set of CORS rules, makes that protection useless against all but the least savvy would be API theives. I'd be happy to learn otherwise...
@eplete2 жыл бұрын
@@jasonthorpe3470 an important feature of cors is to protect requests using cookies. If you create a proxy you will have a different origin so the browser won't send the same cookies. If the api doesn't use cookies, then there isn't much security benefit to cors
@bolatbekyeraliyev3232 жыл бұрын
Jack, amazing content and great presentation. Thank you for covering the frontier of dev tools. A quck question: is there any materials in which you explain how to setup concurrently, wsrun and how to handle errors caused by these tools?
@muhamadluthfia25802 жыл бұрын
Hell yeah man good work
@JGBSolutions2 жыл бұрын
Hey really cool vid as usual. I'm picking some new stuff thanks to you. I have two question:s I see that you use ScreenFlow and I like the effects. Any resources to look at to learn more? I want to make nice videos as well. And what do you use to draw on the screen? I saw you were looking down while doing that. Thanks!
@jherr2 жыл бұрын
For drawing i use a Gaomon tablet and Screenbrush. I do all the code work in Screenflow then use After Effects to put it all toghether.
@JGBSolutions2 жыл бұрын
@@jherr thank you!
@riccardopellegrino54472 жыл бұрын
Hi Jack! I'm new to backend development, what do you mean at 22:10, when you talk about "adding a reporting mechanism on top of REST"? thanks!
@jherr2 жыл бұрын
REST is an entity based model. Your model entities like user, product, and order. You can read, write, update and delete individual entities, and also get lists of that type of entity (e.g. all products.) But you can't get a joined set of entities in that model, for example, all the users that placed orders for a give product. That's why people created a REST API and then bolted on a set of reporting APIs to make up for the limitations of the REST API.
@riccardopellegrino54472 жыл бұрын
@@jherr got it! 😁thank you for your awesome channel
@inversebrah2 жыл бұрын
You're awesome Jack!!!
@Light-nn6hn2 жыл бұрын
Please, when u did npx create-react-app, it showed a bunch of option to select such as if u wanna use css or tailwind How do i get that to work on my pc as well?
@abdelhameedhamdy2 жыл бұрын
Very neat Jack, for those who don't want to expose graphql, is tRPC a good practice to wrap or hide graphql data source ?
@jherr2 жыл бұрын
Yep. IMHO, GraphQL is a good fit for when you have a lot of flexibility on the frontend and the structure of queries may change a lot, or if you are providing a customer API (though that has some issues as well). If you don't fit either of those then something like tRPC is fine because you know the data you need at build time.
@EvanDotJS2 жыл бұрын
Apparently that router method at 3:55 is deprecated now? Not sure if its gonna break my server or not but we'll see!
@technikhil3142 жыл бұрын
Wow this is like prisma but from frontend to backend or cross service calls. Basically remove contract testing.
@amritpalsingh72622 жыл бұрын
can someone tell me what kind of extension is in the video which shows the text autocomplete highlights in the editor as we type.
@jherr2 жыл бұрын
Github Copilot
@eleah26652 жыл бұрын
Very intersting. Thanks.
@DiegoBM2 жыл бұрын
I kind of get the same feeling that I got when I first saw Redux. I was in awe when I saw the time-travelling feature, but I couldn't help but thinking that it was kind of cumbersome to set-up for the value. Maybe they'll improve the API or the general DX in future releases. All in all, I'm not sure to get the full value of tRPC? Maybe I was so hyped before reaching this video, with so many people singing it's wonders of and swearing by it, that it was easy to feel kind of disappointed.
@SumitYadav-bk3jw2 жыл бұрын
Awesome content Can you share your vs code theme?
@AnkurOberoi2 жыл бұрын
Great video! I'm curious, what software/hardware are you using for the on screen annotations with a stylus/pen? It's so seamless!
@jherr2 жыл бұрын
ScreenFlow plus a commodity drawing tablet from Gaomon.
@krishgarg28062 жыл бұрын
It looks a lot like how we make graphql servers. What do you think would be better trpc or graphql server if we know graphql, as we can use the graphql schema to generate type safe code on the client using packages like graphql-code-gen
@v333b2 жыл бұрын
Hey Jack, this video is really helpful and has gotten me more interested in tRPC and typescript. One small thing that left me a little confused is that when you connected the api-server with the client, while this works for the dev process, how would this pan out during deployment? The client would not be able to access the api-server package as it only exists in the local env... Would adding the server as a dev dependency yield the same result?
@pieter-venter2 жыл бұрын
Very good question. You not actually importing any code between the 2 apps. Your simply importing types. In production the types are compiled away. Under the hood trpc makes an http call with the route names. So it's not like the files need to be collocated at all. Ps. We been using trpc for over a year now with Prisma and next and we're hiring. Hit me up on Twitter if you keen to join
@jeielmosi2 жыл бұрын
I'm love with this terminal theme. Is this a zsh theme?
@jherr2 жыл бұрын
Nope, it's oh-my-posh.
@jeielmosi2 жыл бұрын
@@jherr what theme is this?
@jherr2 жыл бұрын
@@jeielmosi Night Wolf [black] and Operator Mono.
@tatenda_mk2 жыл бұрын
So helpful! Thank you
@carlosricardoziegler26502 жыл бұрын
Some examples are using monorepo , right? How can I use it with different repos for front and backend ? Do the app like package ?
@theyreMineralsMarie2 жыл бұрын
How would this work if the API source is in a completely different repo? What if the API is running and hosted on a different server from where the UI static files are served?
@jherr2 жыл бұрын
You'd generate into a shared npm module, or generate into the server module and have the client app consume whichever shared module you created.
@mmmikem2 жыл бұрын
Hey Jack! I'm curious about creating the trpcClient as state here. Why would this be required as opposed to, for example, useCallback? Would this still work? Can you think of any reason to prefer one over the other?
@jherr2 жыл бұрын
Can you give me a time reference?
@mmmikem2 жыл бұрын
@@jherr sure thing! 9:54 should do the trick - sorry that'd have been pertinent considering this is from Feb!
@jherr2 жыл бұрын
@@mmmikem Well, it's not a function, so I wouldn't use `useCallback` but you could use `useMemo` if you want instead, though as some folks have said the docs state that in the future React reserves the right to flush memos to recover space. Or you could use a `useRef` for this, but then you'd need to say `trpcClient.current`, which is not exactly a game changer. Frankly you could probably just pull this out of the component altogether and just define it at the top of the file. I'm not 100% sure why I found it necessary to define it in the component here. As you say, it has been a while since I did this video. Lots of interest in TRPC tho!
@mmmikem2 жыл бұрын
@@jherr ah of course - it's the return of the function that we care about. Oddly enough, I'd thought about whether it *might* need to be invoked inside the component if it was relying on hooks somewhere in there. I feel as though, if that works, it'd be the simplest/cleanest option, as it'd be colocated with the RQ client? I'm gonna give this a bash and see! Thanks for taking the time to respond, really appreciate it!
@matheusvictor96292 жыл бұрын
Well another Con agains GraphQL is that it can't choose what it will be sent to the client, cause in tRPC, what you have on your query is what is going to be sent, right?
@jherr2 жыл бұрын
You mean a con against tRPC right? Yeah, that's correct, the payload is the payload.
@pieter-venter2 жыл бұрын
Hi Jack or anyone that knows, what tool do you use to have the nice graphics with the apple logo and node version? Is it a oh-my-zsh plugin?
@demiann41602 жыл бұрын
Thanks Jack! I have my cross feelings about TRPC. Why would anyone would like to make a non-language agnostic API? So if I'm a python dev, I will have to first learn TS and then TRPC to consume the API?
@jherr2 жыл бұрын
It can be accessed just like any other REST API. It's just easier when you use TypeScript.
@Zagoorland2 жыл бұрын
Can you give some tutorial how to style fonts the way they look in your IDE? Also, what's the name of your theme?
@imichael.2 жыл бұрын
Just FYI: The NPM package for create-mf-app doesn't link to the Github repo
@DB-dk2mj2 жыл бұрын
Please - what is your extension for terminal - so it looks cool!?
@jherr2 жыл бұрын
Fig is what I think you are looking for.
@tubenzr2 жыл бұрын
Hy Jack, Excellent content as always, but I'm always wondering what is your opinion on NodeRed low-code, because I'm amaze with how NodeRed handle business-flow. can you give me one or two opinions on this. thanks so much Sensei.. 🥳
@Neth912 жыл бұрын
i notice a lot of hype about trpc lately but i havent figured out and havent tried it myself yet. is this also beneficial for java backends ? i have very limited fullstack experience and dont know what server this is supporting
@jherr2 жыл бұрын
No, this wouldn't benefit the Java backend world. The idea here is that tRPC is TypeScript on both ends of the pipe, so it makes it easy to define your object types once and use them in both places.
@webdev_telugu2 жыл бұрын
When he installed dependencies with "yarn", why were there no node_modules created in client and api-server
@bhaveekjain42462 жыл бұрын
What fish shell theme are you using?
@vincentgauthier22982 жыл бұрын
hey can you tell me the VS code theme you use? Thanks! Great video.
@jherr2 жыл бұрын
Night Wolf [black] and Operator Mono or JETBrains Mono.
@rcarias782 жыл бұрын
What’s that terminal theme you use. I like that it shows you the full path.
@jherr2 жыл бұрын
Night Wolf [black] and Operator Mono.
@rcarias782 жыл бұрын
@@jherr and how do you get your ZSH terminal to show you the full path
@kiranojha88112 жыл бұрын
@@rcarias78 oh-my-zsh probably
@esotomay212 жыл бұрын
How do you setup ur terminal to give you all those pretty icons
@aleksd2862 жыл бұрын
so TRPC is Graphql without the additional syntax learning? You can also get your types from Graphql server to the client
@Glinkis2 жыл бұрын
You'll have to add a type generation build step for GraphQL though, while tRPC seem to be able to infer the types directly.
@omkarkulkarni36442 жыл бұрын
What font do you use in terminal?
@jherr2 жыл бұрын
SpaceMono NF
@waqasrana57342 жыл бұрын
you are doing great
@kamiljanowski72362 жыл бұрын
Did you just import server code into client code? I know... tree shaking and this is just a quick demo and all but... my eyes are burning 🔥
@jherr2 жыл бұрын
At what time marker?
@hassaannoor2 жыл бұрын
tRPC is great but there seem to be a lot of unnecessary complexities. Telefunc is probably a more literal RPC. Would be fun and helpful to see you try it.
@BezzantSam2 жыл бұрын
It is like reading Dostoyevsky and then trying to pick up a pen and write watching you
@asyncxeno2 жыл бұрын
How did you make the terminal like that?
@willbdev Жыл бұрын
Thanks 🐐
@misterhtmlcss Жыл бұрын
With HTTP2 and the rise of DaaS I do wonder if the value of websockets is as high or broadly useful as it once was. It feels like web sockets is possibly better for niche situations nowadays
@yankee-in-london2 жыл бұрын
Feels like tRPC's assumption about having typescript in the backend is a major limiting factor for it. I did notice a few Rust crates in early stage but unless other languages are designed to support it ... and TS as a type system is amazing for JS but maybe not what you want to marshal to with other languages. For now, I'd say gRPC's relative maturity and multi-language binding makes it a better choice for most RPC projects.
@jherr2 жыл бұрын
I agree with your issues with TS and other languages. But gRPC is no picnic either. I use gRPC every day and the TS generation is pretty flaky. And some of the data type marshaling has issues. Also you have to proxy gRPC it to web clients. So I end up wrapping my gRPC in GraphQL.
@yankee-in-london2 жыл бұрын
@@jherr surprised to hear about the marshaling issues with gRPC but I will admit I don't have a lot of hands on with it ... would have thought a solution in the market as long as gRPC would have worked out all of these kinks. Do you use Zod for validation on the gRPC setup? Seems like that would help in assurances for run time type checks.
@jherr2 жыл бұрын
@@yankee-in-london I don't use Zod for that. The generated TS is good types wise. The marshalling thing comes down to number values. If the number is undefined it still returns zero. So I end up hand code special casing every field that could be nullable, which kinda sucks. I should probably wrap it to make it generic... Ah, well.
@DuyTran-ss4lu2 жыл бұрын
Great as always
@卡卡西-p7i2 жыл бұрын
How do you type so quick, what vscode plugin you use?
@jherr2 жыл бұрын
GitHub Copilot?
@rallokkcaz2 жыл бұрын
Reminds me of FeathersJS and Meteor.
@kashnigahbaruda2 жыл бұрын
Thanks!
@BathingAfrican2 жыл бұрын
I’m tryna transition from fastAPI to gRPC, is there a fundamental difference between the two as to why you’d pick tRPC?
@jherr2 жыл бұрын
Are you talking about the Python fastAPI? If so, then, a big difference would be Node vs Python.
@patite31032 жыл бұрын
Could you please update this video using tRPC V10? Thank so much for your valuable videos!
@ogidarmatena Жыл бұрын
how to deploy this project to vercel?
@BHFJohnny2 жыл бұрын
I wonder why devs decided to create a trpcClient with useState hook. Why not just create it the same way as react query client... I checked tRCP docs, I don't know. I checked your code as changed it, nothing broke, everything still works. Feels like trap, but I think it should be just fine, at least in this case. Maybe it has something to do with async stuff and the new React use hook , I don't know
@housecor2 жыл бұрын
The (obvious) con of tRPC: It requires running TypeScript on the server. So for many teams, that rules it out. That's why GraphQL is so popular - it's a standard that isn't tied to a specific server-side language. But if you're using TypeScript on the server, tRPC a wonderful option that's simpler than GraphQL.
@xamantiwari2 жыл бұрын
Can we use ionic with backend express trpc?
@jherr2 жыл бұрын
I don't see why not.
@ziranshuzhang68312 жыл бұрын
I am trying to see how tRPC is different from the regular REST API, and it seems it is nothing different from REST except the name.
@jherr2 жыл бұрын
It depends on what. you mean by REST. REST isn't a standard. It's an "architectural style". And the only specific thing it covers is the basic verbs associated with entities and collections and the hierarchal relationship between them. Generally speaking REST is both incomplete in that it doesn't allow for one query that involve more than one entity or collection at a time, and also incorrectly structured because the hierarchy of the entities doesn't allow for important permutations of queries. I usually see REST coupled with a set of RPC endpoints. And people just call that "REST" when it's not really anything "standard". Every team/project/company just comes up with their own standards. tRPC is a standard (though not as well specified as GraphQL) and it provides easy end-to-end typing.
@ziranshuzhang68312 жыл бұрын
@@jherr What I mean is that the things you did in the video, seems like I can do all of them with bare ExpressJS with the same amount of effort, and probably even less amount of code. That's what I am not sure why I need tRPC for my project.
@jherr2 жыл бұрын
@@ziranshuzhang6831 You might not. If you don't think that tRPC adds anything then don't use it.
@chengxiaoxia80462 жыл бұрын
- error ``` Error: Debug Failure. False expression: Non-string value passed to `ts.resolveTypeReferenceDirective`, likely by a wrapping package working with an outdated `resolveTypeReferenceDirectives` signature. This is probably not a problem in TS itself. ``` - solution: upgrade version in package.json like below ``` "ts-node": "^10.8.0", "ts-node-dev": "^2.0.0", "typescript": "^4.6.4" ```