blob: 895415b8cdf8a85bc2997fd4089132e5eef068fc [file] [log] [blame]
/*
* Copyright (C) 2022 Savoir-faire Linux Inc.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation; either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public
* License along with this program. If not, see
* <https://www.gnu.org/licenses/>.
*/
import { createSlice, PayloadAction } from '@reduxjs/toolkit';
// Define a type for the slice state
export interface AppState {
// TODO: Remove accountId when account endpoints available.
// Left for backwards compatibility, not necessary, included in token.
accountId: string;
// TODO : Evaluate need for this when WebSocket will be available.
refresh: boolean;
}
// Define the initial state using that type
const initialState: AppState = {
accountId: '',
refresh: true,
};
export const userInfoSlice = createSlice({
name: 'userInfo',
// `createSlice` will infer the state type from the `initialState` argument
initialState,
reducers: {
setAccountId: (state, action: PayloadAction<string>) => {
state.accountId = action.payload;
},
setRefreshFromSlice: (state) => {
state.refresh = !state.refresh;
},
},
});
export const { setAccountId, setRefreshFromSlice } = userInfoSlice.actions;
// Other code such as selectors can use the imported `RootState` type
// export const selectCount = (state: RootState) => state.app.value;
export default userInfoSlice.reducer;