Legend State v3: Local first sync AND fastest React State manager!

  Рет қаралды 22,390

Jack Herrington

Jack Herrington

Күн бұрын

Пікірлер: 62
@MohammedWaseemAnjum
@MohammedWaseemAnjum 10 күн бұрын
Hey jack! you really awesome this 2025! keep it up more tutorials more learnings! thank you so much.
@Valiant600
@Valiant600 3 ай бұрын
Imho, Zustand + RQ is probably the most optimal approach. We use it for production with great results. Always good to have options though.
@lakshmanshankar
@lakshmanshankar 3 ай бұрын
Can u explain for what kind things you guys use zustand for, d u pass state from react query to zustand. How to keep like single src of truth when using both
@Valiant600
@Valiant600 3 ай бұрын
@@lakshmanshankar zustand is mostly for UI state and global state that we cannot handle through server state. For instance, checking if an aside component is open but you change routes and want to check in a different component.
@jherr
@jherr 3 ай бұрын
I love this conversation!
@TianYuanEX
@TianYuanEX 3 ай бұрын
Honestly, I found legend state to be even easier to setup and use than zustand (and more performant according to benchmarks). The only downside was refactoring the code when they updated from v1 to v2 (and now to v3) but even that was a relative breeze There is nothing zustand offers that legend state doesn't, while having better DX and perf, so I see no reason to use anything else as a global state manager (unless it's a very large project already using a different client-side global state manager)
@simransingh1507
@simransingh1507 3 ай бұрын
We replaced Redux Toolkit with Zustand, and it's the best thing we did for our CRM app. It feels lighter, the code structure is way cleaner, less boilerplate. Love Zustand ❤
@yzz9833
@yzz9833 3 ай бұрын
Truly everything I’ve wanted out of a state manager in this new nextjs app router paradigm.
@ImInYourBrains
@ImInYourBrains 3 ай бұрын
I want Legend-State to succeed. I like Zustand but I feel that Legend-State is easier and is more convenient for implementing a lot of signal like reactivity. What it lacks is support, a large community, and many advanced implementations or usages. As someone who has used V1 and currently using V3, it feels like Im in the wild west everytime I investigate issues or try to improve implementation. I will be sending money your way either in the form of Patreon subscription or buying you a coffee in the hopes that you can do a video where you actually build a serious app using Legend-State. Its a large undertaking, so I doubt my wish will come true, but you are one of the only creators that puts out videos about my favorite state-management library...so Im still holding out hope lol
@kiranojha8811
@kiranojha8811 3 ай бұрын
I would rather use mobx with mst
@ImInYourBrains
@ImInYourBrains 3 ай бұрын
@@kiranojha8811 i used mobx too. I still prefer Legend-State. MobX already has a larger userbase so why are people spamming it here? Its annoying. Like, great man. Nobody is stopping you from using it. I want Legend-State to get more attention because it is great and its not replacing MobX. More options is good.
@ImInYourBrains
@ImInYourBrains 3 ай бұрын
@@kiranojha8811 I would rather use LegendState
@flexbox_
@flexbox_ 3 ай бұрын
I am a happy user of Legend State since Chain React #4 because the library have a cool name -that's enough to ship features 🤣
@burhan.yilmaz
@burhan.yilmaz Ай бұрын
Awesome tutorial!
@stephensanwo
@stephensanwo Ай бұрын
What is the strategy for conflict resolution? I am assuming it is last update wins right? In your example where you went offline, changed the client state, and the server state, you did that on two different form fields, it would have been nice to see what would happen if you did that on the same field...Also it will be interesting to see what happens when using this for something like a markdown editor, where you want to merge the changes between two clients, and not necessarily overwrite with the last changes.
@flock4692
@flock4692 3 ай бұрын
I am building an Expo + Supabase social media app and want to use LegendState to store data like the messages on the device. My problem is that my messages model of the app joins different tables, like the users, conversations, and participants tables, to get all the required information. How can I achieve this? As far as I know, I cannot directly join the tables when using the Supabase plugin and put the required data of this specific user in the observable. Do I instead have to get all of the tables and do some basic filtering and then kind of join the observables?
@devfren
@devfren 3 ай бұрын
You need to create a Postgres view. To do all the joins at the database level. Then you can directly query the view with supabase (it acts just like a table)
@whynot9963
@whynot9963 3 ай бұрын
Supabase does support joins. Syntax would be something like from("user").select("*, messages, other stuff"). The first asterisk gets everything from use, and then you say join messages. This would require you to have user_id on messagess. But there is a way also to specify which columns to look for. If joins are super complex, as Jordan mentioned above, go with the view. Or just use Kysely instead of their library
@ivan.jeremic
@ivan.jeremic 3 ай бұрын
MongoDB.
@kristianlavigne8270
@kristianlavigne8270 3 ай бұрын
Yes, using views is the way to go 😊
@flock4692
@flock4692 3 ай бұрын
@@whynot9963 can you use Kysely in the frontend? I thought this was a Edge function thing.
@kartikkaushik4743
@kartikkaushik4743 3 ай бұрын
Thanks jack for the awesome content
@yarrichar
@yarrichar 3 ай бұрын
10:47 - it would have been nice to cover what happens if the same field is updated on the server while you're offline. I assume there's no merging, it's last write wins (including if my browser has been offline for a week)?
@jherr
@jherr 3 ай бұрын
You'd have to implement the logic for the merge yourself. Although from what Jay says support for a merge strategy will be coming in later releases.
@vladimirmryscuk8409
@vladimirmryscuk8409 3 ай бұрын
thanks for the content
@RodrigoCFD
@RodrigoCFD Ай бұрын
MobX has taken this approach years ago...
@lenghak_hok
@lenghak_hok 3 ай бұрын
Sir, could you do a video comparing legend state manager vs nanostores? Really like to how fast legend can do.
@marvinfok65
@marvinfok65 Ай бұрын
Can v3 be use in React Native Expo? Doing a RN expo project currently looking for suitable state management with observable.
@divinenii
@divinenii 27 күн бұрын
yes, I use it in RN, check their docs
@r-i-ch
@r-i-ch 3 ай бұрын
Thanks for the demo! Non-Happy Path?
@somewonderfulguy
@somewonderfulguy 3 ай бұрын
Innit MobX in disguise? ) But seriously, if it Proxies, how well will it go React 19 compiler? This RQ sync seems very powerful. I usually don't mix server & client state but seems like here's another approach.
@vvvvvvvvvwv
@vvvvvvvvvwv 2 ай бұрын
From twitter the creator says you should be able to use react forget compiler alongside Legend state. But since Legend state gives you signal like primitives for fine grained reactivity, I'm not sure if you'll see huge benefits from the compiler.
@RenjithRs123
@RenjithRs123 3 ай бұрын
Signals vs Legend, which state manager os best ?
@jomoc6112
@jomoc6112 3 ай бұрын
wait im a fan of your last video about zustand + react query. is it safe to move to legend state?
@markli7641
@markli7641 3 ай бұрын
there will be data conflict with offline sync . right?
@jherr
@jherr 3 ай бұрын
Right, that's what the code is doing is taking one approach to resolve that conflict. There are multiple patterns for conflict resolution.
@juanvieira8249
@juanvieira8249 2 ай бұрын
Thank you for this! Amazing! Is anyone else getting errors when trying to use "reactive" with the ShadCN Input? Even copying from repo is breaking for me. Using NextJS 15.0.2 and @legendapp/state 3.0.0-beta.15
@EdwinMartin
@EdwinMartin 3 ай бұрын
1:48 Aren’t HOCs a bit obsolete? Why not use hooks that are easier, like other libraries do?
@michaelchristianwisniewski4494
@michaelchristianwisniewski4494 3 ай бұрын
observer isn't a HOC. It is creating a proxy around the component that will track all accessed observables with a single hook
@EdwinMartin
@EdwinMartin 3 ай бұрын
@@michaelchristianwisniewski4494 Oh, I meant HOF. A function that has a function argument and returns a function is a HOF. observer() is a HOF.
@michaelchristianwisniewski4494
@michaelchristianwisniewski4494 3 ай бұрын
@@EdwinMartin Nothing wrong with HOFs. Also the same in the context of functional components. As this is just creating a proxy this still just returns a props->component not a component returning props->component. So no crappy dx with nested components in react dev tools . And this is just the convenient and optimized fast way to handle this. You could also create an observing context inside the component using observe(() => {...})
@LEDsellers
@LEDsellers 3 ай бұрын
Can we just use trpc for the querying, then store the data locally?
@jherr
@jherr 3 ай бұрын
So both tRPC and Legend State are wrapping RQ in this case. So my guess is that you'd probably need to invoke the tRPC call yourself in the Legend State observable hook using RQ. Or check out the implementation of the observable hook and create your own that makes tRPC calls. Technically very possible, but, right out of the box, I don't think so.
@jherr
@jherr 3 ай бұрын
Unless your talking about not using Legend State at all. I mean sure. You can handle storing the data in local storage yourself, and doing the sync logic if that's what you want to do.
@LEDsellers
@LEDsellers 3 ай бұрын
@@jherr Basically I want to query a local version of the data first in an already existing trpc call and use legend instead of zustand for state management. Right now I’m manually doing all of that using zustand via a middleware adapter (indexedDb)
@umardev500
@umardev500 5 күн бұрын
plase make viedeo about legend list too sir
@RusuTraianCristian
@RusuTraianCristian 3 ай бұрын
Using the offline sync feature (via localStorage) will make your app more susceptible to attacks, as localStorage is very much not safe. Maybe I am missing something?
@trejohnson7677
@trejohnson7677 3 ай бұрын
Legend state + xstate
@thisweekinreact
@thisweekinreact 3 ай бұрын
first
@ilyasanders4169
@ilyasanders4169 3 ай бұрын
The best state manager is MobX
@im7254
@im7254 3 ай бұрын
Nextjs = garbage
@somewonderfulguy
@somewonderfulguy 3 ай бұрын
Your opinion is very important to everybody.
React 19's useOptimistic: EVERYTHING you NEED to know
25:24
Jack Herrington
Рет қаралды 17 М.
Making React Context FAST!
33:34
Jack Herrington
Рет қаралды 91 М.
To Brawl AND BEYOND!
00:51
Brawl Stars
Рет қаралды 17 МЛН
Tuna 🍣 ​⁠@patrickzeinali ​⁠@ChefRush
00:48
albert_cancook
Рет қаралды 148 МЛН
How to treat Acne💉
00:31
ISSEI / いっせい
Рет қаралды 108 МЛН
Local-First is the Future, Here’s Why
14:51
Simon Grimm
Рет қаралды 25 М.
Stop Using useEffect With Redux!
8:02
Jack Herrington
Рет қаралды 27 М.
5 Hidden React Server Function TRAPS Beginners Fall Into
21:31
Jack Herrington
Рет қаралды 11 М.
Picking From 20 React State Managers
35:18
Jack Herrington
Рет қаралды 86 М.
Unintuitive behaviors of React Hooks
16:26
Theo - t3․gg
Рет қаралды 27 М.
React visually explained: 'use client'
15:57
Delba
Рет қаралды 62 М.
State Management in React Will Never Be the Same
15:21
Austin Davis
Рет қаралды 18 М.
To Brawl AND BEYOND!
00:51
Brawl Stars
Рет қаралды 17 МЛН