* Change to using arrow functions Co-authored-by: v1b3m <vibenjamin6@gmail.com> Co-authored-by: Matheus <matheus_benini@hotmail.com> * Add lint rule --------- Co-authored-by: v1b3m <vibenjamin6@gmail.com> Co-authored-by: Matheus <matheus_benini@hotmail.com> Co-authored-by: Charles Bochet <charles@twenty.com>
23 lines
730 B
TypeScript
23 lines
730 B
TypeScript
import { Context, useContext } from 'react';
|
|
import { RecoilState, useRecoilState } from 'recoil';
|
|
|
|
import { RecoilScopeContext } from '../states/RecoilScopeContext';
|
|
|
|
export const useRecoilScopedState = <StateType>(
|
|
recoilState: (param: string) => RecoilState<StateType>,
|
|
CustomRecoilScopeContext?: Context<string | null>,
|
|
) => {
|
|
const recoilScopeId = useContext(
|
|
CustomRecoilScopeContext ?? RecoilScopeContext,
|
|
);
|
|
|
|
if (!recoilScopeId)
|
|
throw new Error(
|
|
`Using a scoped atom without a RecoilScope : ${
|
|
recoilState('').key
|
|
}, verify that you are using a RecoilScope with a specific context if you intended to do so.`,
|
|
);
|
|
|
|
return useRecoilState<StateType>(recoilState(recoilScopeId));
|
|
};
|