mirror of
https://github.com/grafana/grafana.git
synced 2025-02-15 10:03:33 -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>
40 lines
1.2 KiB
TypeScript
40 lines
1.2 KiB
TypeScript
import { ThunkResult } from '../../../types';
|
|
import { getBackendSrv } from '@grafana/runtime';
|
|
import { OrgUser } from 'app/types';
|
|
import { inviteesLoaded, usersLoaded } from './reducers';
|
|
|
|
export function loadUsers(): ThunkResult<void> {
|
|
return async dispatch => {
|
|
const users = await getBackendSrv().get('/api/org/users');
|
|
dispatch(usersLoaded(users));
|
|
};
|
|
}
|
|
|
|
export function loadInvitees(): ThunkResult<void> {
|
|
return async dispatch => {
|
|
const invitees = await getBackendSrv().get('/api/org/invites');
|
|
dispatch(inviteesLoaded(invitees));
|
|
};
|
|
}
|
|
|
|
export function updateUser(user: OrgUser): ThunkResult<void> {
|
|
return async dispatch => {
|
|
await getBackendSrv().patch(`/api/org/users/${user.userId}`, { role: user.role });
|
|
dispatch(loadUsers());
|
|
};
|
|
}
|
|
|
|
export function removeUser(userId: number): ThunkResult<void> {
|
|
return async dispatch => {
|
|
await getBackendSrv().delete(`/api/org/users/${userId}`);
|
|
dispatch(loadUsers());
|
|
};
|
|
}
|
|
|
|
export function revokeInvite(code: string): ThunkResult<void> {
|
|
return async dispatch => {
|
|
await getBackendSrv().patch(`/api/org/invites/${code}/revoke`, {});
|
|
dispatch(loadInvitees());
|
|
};
|
|
}
|