mirror of
https://github.com/grafana/grafana.git
synced 2025-02-15 01:53:33 -06:00
97 lines
2.4 KiB
TypeScript
97 lines
2.4 KiB
TypeScript
import { createSlice, PayloadAction } from '@reduxjs/toolkit';
|
|
|
|
import config from 'app/core/config';
|
|
import { OrgUser, UsersState } from 'app/types';
|
|
|
|
export const initialState: UsersState = {
|
|
users: [],
|
|
searchQuery: '',
|
|
page: 0,
|
|
perPage: 30,
|
|
totalPages: 1,
|
|
externalUserMngInfo: config.externalUserMngInfo,
|
|
externalUserMngLinkName: config.externalUserMngLinkName,
|
|
externalUserMngLinkUrl: config.externalUserMngLinkUrl,
|
|
isLoading: false,
|
|
rolesLoading: false,
|
|
};
|
|
|
|
export interface UsersFetchResult {
|
|
orgUsers: OrgUser[];
|
|
perPage: number;
|
|
page: number;
|
|
totalCount: number;
|
|
}
|
|
|
|
export interface UsersRolesFetchResult {
|
|
orgUsers: OrgUser[];
|
|
perPage: number;
|
|
page: number;
|
|
totalCount: number;
|
|
}
|
|
|
|
const usersSlice = createSlice({
|
|
name: 'users',
|
|
initialState,
|
|
reducers: {
|
|
usersLoaded: (state, action: PayloadAction<UsersFetchResult>): UsersState => {
|
|
const { totalCount, perPage, page, orgUsers } = action.payload;
|
|
const totalPages = Math.ceil(totalCount / perPage);
|
|
|
|
return {
|
|
...state,
|
|
isLoading: true,
|
|
users: orgUsers,
|
|
perPage,
|
|
page,
|
|
totalPages,
|
|
};
|
|
},
|
|
searchQueryChanged: (state, action: PayloadAction<string>): UsersState => {
|
|
// reset searchPage otherwise search results won't appear
|
|
return { ...state, searchQuery: action.payload, page: initialState.page };
|
|
},
|
|
setUsersSearchPage: (state, action: PayloadAction<number>): UsersState => {
|
|
return { ...state, page: action.payload };
|
|
},
|
|
pageChanged: (state, action: PayloadAction<number>) => ({
|
|
...state,
|
|
page: action.payload,
|
|
}),
|
|
sortChanged: (state, action: PayloadAction<UsersState['sort']>) => ({
|
|
...state,
|
|
sort: action.payload,
|
|
}),
|
|
usersFetchBegin: (state) => {
|
|
return { ...state, isLoading: true };
|
|
},
|
|
usersFetchEnd: (state) => {
|
|
return { ...state, isLoading: false };
|
|
},
|
|
rolesFetchBegin: (state) => {
|
|
return { ...state, rolesLoading: true };
|
|
},
|
|
rolesFetchEnd: (state) => {
|
|
return { ...state, rolesLoading: false };
|
|
},
|
|
},
|
|
});
|
|
|
|
export const {
|
|
searchQueryChanged,
|
|
setUsersSearchPage,
|
|
usersLoaded,
|
|
usersFetchBegin,
|
|
usersFetchEnd,
|
|
pageChanged,
|
|
sortChanged,
|
|
rolesFetchBegin,
|
|
rolesFetchEnd,
|
|
} = usersSlice.actions;
|
|
|
|
export const usersReducer = usersSlice.reducer;
|
|
|
|
export default {
|
|
users: usersReducer,
|
|
};
|