mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-10 23:45:44 +01:00
merge heads
This commit is contained in:
@@ -1,7 +1,17 @@
|
||||
// @flow
|
||||
import { apiClient, NOT_FOUND_ERROR } from "../../apiclient";
|
||||
import type { User } from "../types/User";
|
||||
import { ThunkDispatch } from "redux-thunk";
|
||||
import {
|
||||
apiClient,
|
||||
NOT_FOUND_ERROR
|
||||
} from "../../apiclient";
|
||||
import type {
|
||||
User
|
||||
} from "../types/User";
|
||||
import type {
|
||||
UserEntry
|
||||
} from "../types/UserEntry";
|
||||
import {
|
||||
Dispatch
|
||||
} from "redux";
|
||||
|
||||
export const FETCH_USERS = "scm/users/FETCH";
|
||||
export const FETCH_USERS_SUCCESS = "scm/users/FETCH_SUCCESS";
|
||||
@@ -13,8 +23,10 @@ export const ADD_USER_SUCCESS = "scm/users/ADD_SUCCESS";
|
||||
export const ADD_USER_FAILURE = "scm/users/ADD_FAILURE";
|
||||
|
||||
export const EDIT_USER = "scm/users/EDIT";
|
||||
export const EDIT_USER_SUCCESS = "scm/users/EDIT_SUCCESS";
|
||||
export const EDIT_USER_FAILURE = "scm/users/EDIT_FAILURE";
|
||||
|
||||
export const UPDATE_USER = "scm/users/UPDATE";
|
||||
export const UPDATE_USER_SUCCESS = "scm/users/UPDATE_SUCCESS";
|
||||
export const UPDATE_USER_FAILURE = "scm/users/UPDATE_FAILURE";
|
||||
|
||||
export const DELETE_USER = "scm/users/DELETE";
|
||||
export const DELETE_USER_SUCCESS = "scm/users/DELETE_SUCCESS";
|
||||
@@ -23,6 +35,7 @@ export const DELETE_USER_FAILURE = "scm/users/DELETE_FAILURE";
|
||||
const USERS_URL = "users";
|
||||
|
||||
const CONTENT_TYPE_USER = "application/vnd.scmm-user+json;v=2";
|
||||
|
||||
function requestUsers() {
|
||||
return {
|
||||
type: FETCH_USERS
|
||||
@@ -45,7 +58,7 @@ function usersNotFound(url: string) {
|
||||
}
|
||||
|
||||
export function fetchUsers() {
|
||||
return function(dispatch: any) {
|
||||
return function (dispatch: any) {
|
||||
dispatch(requestUsers());
|
||||
return apiClient
|
||||
.get(USERS_URL)
|
||||
@@ -85,7 +98,7 @@ function requestAddUser(user: User) {
|
||||
}
|
||||
|
||||
export function addUser(user: User) {
|
||||
return function(dispatch: ThunkDispatch) {
|
||||
return function (dispatch: Dispatch) {
|
||||
dispatch(requestAddUser(user));
|
||||
return apiClient
|
||||
.postWithContentType(USERS_URL, user, CONTENT_TYPE_USER)
|
||||
@@ -111,36 +124,36 @@ function addUserFailure(user: User, err: Error) {
|
||||
};
|
||||
}
|
||||
|
||||
function requestAddUser(user: User) {
|
||||
function requestUpdateUser(user: User) {
|
||||
return {
|
||||
type: ADD_USER,
|
||||
type: UPDATE_USER,
|
||||
user
|
||||
};
|
||||
}
|
||||
|
||||
export function editUser(user: User) {
|
||||
return function(dispatch: ThunkDispatch) {
|
||||
dispatch(requestAddUser(user));
|
||||
export function updateUser(user: User) {
|
||||
return function (dispatch: Dispatch) {
|
||||
dispatch(requestUpdateUser(user));
|
||||
return apiClient
|
||||
.putWithContentType(USERS_URL + "/" + user.name, user, CONTENT_TYPE_USER)
|
||||
.putWithContentType(user._links.update.href, user, CONTENT_TYPE_USER)
|
||||
.then(() => {
|
||||
dispatch(addUserSuccess());
|
||||
dispatch(updateUserSuccess());
|
||||
dispatch(fetchUsers());
|
||||
})
|
||||
.catch(err => dispatch(addUserFailure(user, err)));
|
||||
.catch(err => dispatch(updateUserFailure(user, err)));
|
||||
};
|
||||
}
|
||||
|
||||
function editUserSuccess() {
|
||||
function updateUserSuccess() {
|
||||
return {
|
||||
type: ADD_USER_SUCCESS
|
||||
type: UPDATE_USER_SUCCESS
|
||||
};
|
||||
}
|
||||
|
||||
function addUserFailure(user: User, err: Error) {
|
||||
function updateUserFailure(user: User, error: Error) {
|
||||
return {
|
||||
type: ADD_USER_FAILURE,
|
||||
payload: err,
|
||||
type: UPDATE_USER_FAILURE,
|
||||
payload: error,
|
||||
user
|
||||
};
|
||||
}
|
||||
@@ -167,7 +180,7 @@ function deleteUserFailure(url: string, err: Error) {
|
||||
}
|
||||
|
||||
export function deleteUser(link: string) {
|
||||
return function(dispatch: ThunkDispatch) {
|
||||
return function (dispatch: ThunkDispatch) {
|
||||
dispatch(requestDeleteUser(link));
|
||||
return apiClient
|
||||
.delete(link)
|
||||
@@ -187,7 +200,7 @@ export function getUsersFromState(state) {
|
||||
if (!userNames) {
|
||||
return null;
|
||||
}
|
||||
var userEntries = new Array();
|
||||
var userEntries: Array < UserEntry > = [];
|
||||
|
||||
for (let userName of userNames) {
|
||||
userEntries.push(state.users.usersByNames[userName]);
|
||||
@@ -197,8 +210,8 @@ export function getUsersFromState(state) {
|
||||
}
|
||||
|
||||
function extractUsersByNames(
|
||||
users: Array<User>,
|
||||
userNames: Array<string>,
|
||||
users: Array < User > ,
|
||||
userNames: Array < string > ,
|
||||
oldUsersByNames: {}
|
||||
) {
|
||||
var usersByNames = {};
|
||||
@@ -215,6 +228,13 @@ function extractUsersByNames(
|
||||
return usersByNames;
|
||||
}
|
||||
|
||||
export function editUser(user: User) {
|
||||
return {
|
||||
type: EDIT_USER,
|
||||
user
|
||||
};
|
||||
}
|
||||
|
||||
export default function reducer(state: any = {}, action: any = {}) {
|
||||
switch (action.type) {
|
||||
case FETCH_USERS:
|
||||
@@ -254,14 +274,18 @@ export default function reducer(state: any = {}, action: any = {}) {
|
||||
...state,
|
||||
error: action.payload,
|
||||
loading: false
|
||||
};
|
||||
};
|
||||
case DELETE_USER_FAILURE:
|
||||
return {
|
||||
...state,
|
||||
error: action.payload,
|
||||
loading: false
|
||||
};
|
||||
|
||||
return {
|
||||
...state,
|
||||
error: action.payload,
|
||||
loading: false
|
||||
};
|
||||
case EDIT_USER:
|
||||
return {
|
||||
...state,
|
||||
editUser: action.user
|
||||
};
|
||||
default:
|
||||
return state;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user