i need help on type

No description
No description
Solution:
```typescript export function StoreSetter<T extends keyof StoreType>({ store, data, }: {...
Jump to solution
29 Replies
erik.gh
erik.gh12mo ago
bro what
DGCP3
DGCP3OP12mo ago
i want to add type to data prop in StoreSetter component
erik.gh
erik.gh12mo ago
and what’s the issue?
DGCP3
DGCP3OP12mo ago
should i send screen shot or copy paste the error
erik.gh
erik.gh12mo ago
both is fine
DGCP3
DGCP3OP12mo ago
ok i did this few min ago and
export function StoreSetter<T extends keyof StoreType, K extends StoreType[keyof StoreType]["init"]>({
store,
data,
}: {
store: T;
data: K;
}) {
const [, setAtom] = useAtom(stores[store]);

setAtom(data);

return null;
}
export function StoreSetter<T extends keyof StoreType, K extends StoreType[keyof StoreType]["init"]>({
store,
data,
}: {
store: T;
data: K;
}) {
const [, setAtom] = useAtom(stores[store]);

setAtom(data);

return null;
}
DGCP3
DGCP3OP12mo ago
then this error is shown at top of setAtom(data)
No description
Solution
erik.gh
erik.gh12mo ago
export function StoreSetter<T extends keyof StoreType>({
store,
data,
}: {
store: T;
data: ExtractAtomArgs<StoreType[T]>;
}) {
const [, setAtom] = useAtom(stores[store]);

setAtom(...data);

return null;
}
export function StoreSetter<T extends keyof StoreType>({
store,
data,
}: {
store: T;
data: ExtractAtomArgs<StoreType[T]>;
}) {
const [, setAtom] = useAtom(stores[store]);

setAtom(...data);

return null;
}
erik.gh
erik.gh12mo ago
with StoreSetter({store: 'write2', data: [""]})
DGCP3
DGCP3OP12mo ago
i have another request if you dont mind
erik.gh
erik.gh12mo ago
sure go ahead
DGCP3
DGCP3OP12mo ago
its ok, to set setAtom(...data) like that right, when I use useeffect it throws a hydration error because initially, it render empty form then get populated
erik.gh
erik.gh12mo ago
btw not sure if you really want to pass the parameters as object you could also do this:
export function StoreSetter<T extends keyof StoreType>(
store: T,
...data: ExtractAtomArgs<StoreType[T]>
) {
const [, setAtom] = useAtom(stores[store]);
setAtom(...data);
return null;
}
export function StoreSetter<T extends keyof StoreType>(
store: T,
...data: ExtractAtomArgs<StoreType[T]>
) {
const [, setAtom] = useAtom(stores[store]);
setAtom(...data);
return null;
}
and use it like this:
StoreSetter("write2", "jsdlfj", "second", "third", ...)
StoreSetter("write2", "jsdlfj", "second", "third", ...)
which i find to be nicer
DGCP3
DGCP3OP12mo ago
No description
erik.gh
erik.gh12mo ago
so you want to use it as a component?
DGCP3
DGCP3OP12mo ago
this is the whole picture, I have 5 tabs that are all client-side, and depending on the query(tab) URL I render them. but I want to fetch the initial data on the server side and pass the data to those tabs that contain multiple forms. so instead of drilling them via props, I created the store-setter component that receives data as a prop from the server side and sets the store. and the forms just get the initial data from the store.
erik.gh
erik.gh12mo ago
okay i see then forget this ☝️
DGCP3
DGCP3OP12mo ago
what do you think about this and btw this shows error when i use writable atom, but works with normal atom
erik.gh
erik.gh12mo ago
tbh i am not really sure - haven't used jotai with server components yet so your approach is new to me
DGCP3
DGCP3OP12mo ago
I didn't use it on the server side, i just passed data from the server side to the client(via prop) and then set the atom on the client side
erik.gh
erik.gh12mo ago
yeah normally you'd use a useEffect for setting an atoms value
erik.gh
erik.gh12mo ago
GitHub
Can an atom be initialised on the first render? · pmndrs jotai · Di...
I think I have a use case not sure if it's covered. I'm trying to replace a useState with useAtom but I can't provide an initial state with the atom except after the hook is initialised...
erik.gh
erik.gh12mo ago
i think the provider approach is quite literally what you're building yourself rn
erik.gh
erik.gh12mo ago
Jotai
SSR — Jotai, primitive and flexible state management for React
Jotai takes a bottom-up approach to global React state management with an atomic model inspired by Recoil. One can build state by combining atoms and renders are optimized based on atom dependency. This solves the extra re-render issue of React context and eliminates the need for memoization.
DGCP3
DGCP3OP12mo ago
Yes you are right, but when I tried it it doesn't work Isn't this only supported only for next 12 and before that, next 13 broke it I think
erik.gh
erik.gh12mo ago
yeah i think you're right
DGCP3
DGCP3OP12mo ago
Maybe I should just use context with useReducer And using useEffect ain't possible, tried it it keeps failing, and without it it works fine🤞
DGCP3
DGCP3OP12mo ago
thank you for your help mate
erik.gh
erik.gh12mo ago
sure!

Did you find this page helpful?