mirror of
https://github.com/grafana/grafana.git
synced 2025-02-09 06:56:07 -06:00
* Refactor: Adds Redux Toolkit package * Refactor: Uses configureStore from Redux Toolkit * Refactor: Migrates applicationReducer * Refactor: Migrates appNotificationsReducer * Refactor: Migrates locationReducer * Refactor: Migrates navModelReducer * Refactor: Migrates teamsReducer and teamReducer * Refactor: Migrates cleanUpAction * Refactor: Migrates alertRulesReducer * Refactor: Cleans up recursiveCleanState * Refactor: Switched to Angular compatible reducers * Refactor: Migrates folderReducer * Refactor: Migrates dashboardReducer * Migrates panelEditorReducer * Refactor: Migrates dataSourcesReducer * Refactor: Migrates usersReducer * Refactor: Migrates organizationReducer * Refactor: Migrates pluginsReducer * Refactor: Migrates ldapReducer and ldapUserReducer * Refactor: Migrates apiKeysReducer * Refactor: Migrates exploreReducer and itemReducer * Refactor: Removes actionCreatorFactory and reducerFactory * Refactor: Moves mocks to test section * Docs: Removes sections about home grown framework * Update contribute/style-guides/redux.md Co-Authored-By: Diana Payton <52059945+oddlittlebird@users.noreply.github.com> * Refactor: Cleans up some code * Refactor: Adds state typings * Refactor: Cleans up typings * Refactor: Adds comment about ImmerJs autoFreeze Co-authored-by: Diana Payton <52059945+oddlittlebird@users.noreply.github.com>
58 lines
1.8 KiB
TypeScript
58 lines
1.8 KiB
TypeScript
import { createSlice, PayloadAction } from '@reduxjs/toolkit';
|
|
|
|
import { Team, TeamGroup, TeamMember, TeamsState, TeamState } from 'app/types';
|
|
|
|
export const initialTeamsState: TeamsState = { teams: [], searchQuery: '', hasFetched: false };
|
|
|
|
const teamsSlice = createSlice({
|
|
name: 'teams',
|
|
initialState: initialTeamsState,
|
|
reducers: {
|
|
teamsLoaded: (state, action: PayloadAction<Team[]>): TeamsState => {
|
|
return { ...state, hasFetched: true, teams: action.payload };
|
|
},
|
|
setSearchQuery: (state, action: PayloadAction<string>): TeamsState => {
|
|
return { ...state, searchQuery: action.payload };
|
|
},
|
|
},
|
|
});
|
|
|
|
export const { teamsLoaded, setSearchQuery } = teamsSlice.actions;
|
|
|
|
export const teamsReducer = teamsSlice.reducer;
|
|
|
|
export const initialTeamState: TeamState = {
|
|
team: {} as Team,
|
|
members: [] as TeamMember[],
|
|
groups: [] as TeamGroup[],
|
|
searchMemberQuery: '',
|
|
};
|
|
|
|
const teamSlice = createSlice({
|
|
name: 'team',
|
|
initialState: initialTeamState,
|
|
reducers: {
|
|
teamLoaded: (state, action: PayloadAction<Team>): TeamState => {
|
|
return { ...state, team: action.payload };
|
|
},
|
|
teamMembersLoaded: (state, action: PayloadAction<TeamMember[]>): TeamState => {
|
|
return { ...state, members: action.payload };
|
|
},
|
|
setSearchMemberQuery: (state, action: PayloadAction<string>): TeamState => {
|
|
return { ...state, searchMemberQuery: action.payload };
|
|
},
|
|
teamGroupsLoaded: (state, action: PayloadAction<TeamGroup[]>): TeamState => {
|
|
return { ...state, groups: action.payload };
|
|
},
|
|
},
|
|
});
|
|
|
|
export const { teamLoaded, teamGroupsLoaded, teamMembersLoaded, setSearchMemberQuery } = teamSlice.actions;
|
|
|
|
export const teamReducer = teamSlice.reducer;
|
|
|
|
export default {
|
|
teams: teamsReducer,
|
|
team: teamReducer,
|
|
};
|