about summary refs log blame commit diff
path: root/users/wpcarro/boilerplate/typescript/src/store.ts
blob: 03e980a491cc3c7a6818231c99e14521f497ce7e (plain) (tree)

























                                                                                
import { createSlice, configureStore, PayloadAction } from "@reduxjs/toolkit";
import { useSelector, TypedUseSelectorHook } from "react-redux";

export interface State {
  isLoading: boolean;
}

const initialState: State = {
  isLoading: true,
};

export const { actions, reducer } = createSlice({
  name: "application",
  initialState,
  reducers: {
    toggleIsLoading: state => ({ ...state, isLoading: !state.isLoading }),
  }
});

/**
 * Defining and consuming this allows us to avoid annotating State in all of our
 * selectors.
 */
export const useTypedSelector: TypedUseSelectorHook<State> = useSelector;

export default configureStore({ reducer });