Is there a way to hydrate signals on the server?

I have an AuthContext. I just specifically want to hydrate my user signal in some routes. Is there a way to do this? As far as I know, even in React I can't do this unless I bring in a separate library. Jotai actually does this using useHydrateAtoms. I'm wondering if there's something similar in SolidJS that I can use? (Not Solid Start specific). https://jotai.org/docs/utilities/ssr
// imports...

export type AuthContextValue = {
user: Accessor<{ id: string; username: string } | null>;
loading: Accessor<boolean>;
login: (username: string, password: string) => Promise<ReturnType<AuthContextValue['user']>>;
logout: () => Promise<{ success: boolean }>;
register: (username: string, password: string) => Promise<ReturnType<AuthContextValue['user']>>;
};

const AuthContext = createContext({
user: () => null,
loading: () => false,
login: async (username: string, password: string) => null,
logout: async () => ({ success: false }),
register: async (username: string, password: string) => null
} as AuthContextValue);

export const useAuthContext = () => useContext(AuthContext);

export const AuthContextProvider: FlowComponent = (props) => {
const [user, setUser] = createSignal<ReturnType<AuthContextValue['user']>>(null);
const [loading, setLoading] = createSignal<boolean>(false);

// ...

return (
<AuthContext.Provider
value={{
user,
loading,
register,
login,
logout
}}
>
{props.children}
</AuthContext.Provider>
);
};
// imports...

export type AuthContextValue = {
user: Accessor<{ id: string; username: string } | null>;
loading: Accessor<boolean>;
login: (username: string, password: string) => Promise<ReturnType<AuthContextValue['user']>>;
logout: () => Promise<{ success: boolean }>;
register: (username: string, password: string) => Promise<ReturnType<AuthContextValue['user']>>;
};

const AuthContext = createContext({
user: () => null,
loading: () => false,
login: async (username: string, password: string) => null,
logout: async () => ({ success: false }),
register: async (username: string, password: string) => null
} as AuthContextValue);

export const useAuthContext = () => useContext(AuthContext);

export const AuthContextProvider: FlowComponent = (props) => {
const [user, setUser] = createSignal<ReturnType<AuthContextValue['user']>>(null);
const [loading, setLoading] = createSignal<boolean>(false);

// ...

return (
<AuthContext.Provider
value={{
user,
loading,
register,
login,
logout
}}
>
{props.children}
</AuthContext.Provider>
);
};
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.
1 Reply
Blankeos
BlankeosOP8mo ago
Okay, I now realize I can actually just set it as part of the initial state and it would be included in the html response. createSignal(initialState)

Did you find this page helpful?