Joint State Pattern (JSP) #61
Replies: 4 comments 1 reply
-
Very simple joint state in import { useStore } from '@tanstack/react-store';
import { Store } from '@tanstack/store';
interface IEntitiesStore {
// properties here
entity0: string;
}
// state
const state = {
entities: new Store<IEntitiesStore>({
entity0: '',
}),
};
// getters
export const getters = {
getLastEntities: () => {
return state.entities.state;
},
};
// actions
const actions = {
updateEntities: (payload: Partial<IEntitiesStore>) => {
state.entities.setState((prev) => ({
...prev,
...payload,
}));
},
};
// hook
type UseEntitiesStore = [
{ entities: IEntitiesStore },
{
getters: typeof getters;
},
{
actions: typeof actions;
},
];
export const useFiltersStore = (): UseEntitiesStore => [
{
entities: useStore(state.entities, (state) => state),
},
{
getters,
},
{
actions,
},
]; |
Beta Was this translation helpful? Give feedback.
-
They are a convenient way to share global state between components but should be used wisely in large components to avoid unnecessary complexity. In small components, there's no significant difference between using joint state or local state. |
Beta Was this translation helpful? Give feedback.
-
In VanJS for complex states better to use this |
Beta Was this translation helpful? Give feedback.
-
Joint State Pattern (JSP) – A Pattern to Reduce Boilerplate
I want to standardise the approach to state management across frameworks and libraries, writing in a similar style with core conditions (see next 4 conditions in the end of the article).
This article discusses this pattern.
In the case of
VanJS
, you can usevan.state
.In
Raw
, you can useraw.signal
.In
React
it's a little bit complicated.You should use some
state
and some hookuseState
(/TanStack/store/blob/main/packages/react-store/src/index.ts).Joint State Pattern (JSP) cover
TanStack Store
, which helps reduce boilerplate (see example with theme).Also it can be scaled to
nanostores
, for instance.TanStack Store is based on React’s useSyncExternalStore — a hook introduced to simplify and improve the management of external data stores.
Before TanStack Store was something like
MobX
:Example on GitHub
While JSP can be implemented with MobX, I am personally not focusing on that approach.
However, there are edge cases to consider, such as working with private fields or nested arrays/objects.
So, Core Conditions for Joint State Pattern (JSP):
Minimize the amount of repetitive setup code required to define stores. This makes it easier to manage shared state without the overhead of redundant code.
• Store Structure
When creating stores, keep them consistent with a clear, standard structure. Specifically:
• Start by initializing the store, and end by exporting the hook.
This ensures that each store is straightforward to use and import across the app.
• Define state, getters, actions, and exports.
These elements should be clearly outlined within each store, providing an organized and predictable setup for accessing and updating shared state.
Shared state should be accessible directly between components, without additional setup. In React, this means simply importing useStore to access the shared state — no need to wrap components in an observe function or similar constructs. This setup makes the state more easily available and reduces dependencies on extra state management wrappers.
Beta Was this translation helpful? Give feedback.
All reactions