mirror of
https://github.com/grafana/grafana.git
synced 2025-02-15 10:03:33 -06:00
* Role picker: Load users roles in batch * Use orgId in request * Add roles to OrgUser type * Improve loading logic * Improve loading indicator * Fix org page * Update service accounts page * Use bulk roles query for teams * Use POST requests for search * Use post request for teams * Update betterer results * Review suggestions * AdminEditOrgPage: move API calls to separate file
89 lines
2.5 KiB
TypeScript
89 lines
2.5 KiB
TypeScript
import { createSlice, PayloadAction } from '@reduxjs/toolkit';
|
|
|
|
import { Team, TeamGroup, TeamMember, TeamsState, TeamState } from 'app/types';
|
|
|
|
export const initialTeamsState: TeamsState = {
|
|
teams: [],
|
|
page: 1,
|
|
query: '',
|
|
perPage: 30,
|
|
totalPages: 0,
|
|
noTeams: false,
|
|
hasFetched: false,
|
|
};
|
|
|
|
type TeamsFetched = {
|
|
teams: Team[];
|
|
page: number;
|
|
perPage: number;
|
|
noTeams: boolean;
|
|
totalCount: number;
|
|
};
|
|
|
|
const teamsSlice = createSlice({
|
|
name: 'teams',
|
|
initialState: initialTeamsState,
|
|
reducers: {
|
|
teamsLoaded: (state, action: PayloadAction<TeamsFetched>): TeamsState => {
|
|
const { totalCount, perPage, ...rest } = action.payload;
|
|
const totalPages = Math.ceil(totalCount / perPage);
|
|
return { ...state, ...rest, totalPages, perPage, hasFetched: true };
|
|
},
|
|
queryChanged: (state, action: PayloadAction<string>): TeamsState => {
|
|
return { ...state, page: 1, query: action.payload };
|
|
},
|
|
pageChanged: (state, action: PayloadAction<number>): TeamsState => {
|
|
return { ...state, page: action.payload };
|
|
},
|
|
sortChanged: (state, action: PayloadAction<TeamsState['sort']>): TeamsState => {
|
|
return { ...state, sort: action.payload, page: 1 };
|
|
},
|
|
rolesFetchBegin: (state) => {
|
|
return { ...state, rolesLoading: true };
|
|
},
|
|
rolesFetchEnd: (state) => {
|
|
return { ...state, rolesLoading: false };
|
|
},
|
|
},
|
|
});
|
|
|
|
export const { teamsLoaded, queryChanged, pageChanged, sortChanged, rolesFetchBegin, rolesFetchEnd } =
|
|
teamsSlice.actions;
|
|
|
|
export const teamsReducer = teamsSlice.reducer;
|
|
|
|
export const initialTeamState: TeamState = {
|
|
team: {} as Team,
|
|
members: [],
|
|
groups: [],
|
|
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,
|
|
};
|