-
Notifications
You must be signed in to change notification settings - Fork 1
/
index.ts
31 lines (27 loc) · 1.22 KB
/
index.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
import { configureStore } from "@reduxjs/toolkit";
import { useDispatch, TypedUseSelectorHook, useSelector } from "react-redux";
import repoSlice from "@slices/repos";
import { recommendationsApi } from "@features/repos/api/getRecommendations";
import { repoInfoApi } from "@features/info/api/getRepoInfo";
import middlewares from "./middlewares";
import { createWrapper } from "next-redux-wrapper";
export const makeStore = () =>
configureStore({
reducer: {
[repoSlice.name]: repoSlice.reducer,
[recommendationsApi.reducerPath]: recommendationsApi.reducer,
[repoInfoApi.reducerPath]: repoInfoApi.reducer,
},
// @ts-ignore
middleware: getDefaultMiddleware => getDefaultMiddleware().concat(middlewares),
devTools: process.env.NODE_ENV === "development",
});
export type AppStore = ReturnType<typeof makeStore>;
export type RootState = ReturnType<AppStore["getState"]>;
export type AppDispatch = AppStore["dispatch"];
export const useAppDispatch = () => useDispatch<AppDispatch>();
export const useAppSelector: TypedUseSelectorHook<RootState> = useSelector;
export const wrapper = createWrapper<AppStore>(makeStore, {
debug: process.env.NODE_ENV === "development",
});
export const store = makeStore();