mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-08 14:35:45 +01:00
Fixed merge bugs
This commit is contained in:
@@ -66,10 +66,16 @@ class Users extends React.Component<Props, User> {
|
|||||||
|
|
||||||
const mapStateToProps = state => {
|
const mapStateToProps = state => {
|
||||||
const userEntries = getUsersFromState(state);
|
const userEntries = getUsersFromState(state);
|
||||||
|
let error = null;
|
||||||
|
let canAddUsers = false;
|
||||||
|
if (state.users && state.users.users) {
|
||||||
|
error = state.users.users.error;
|
||||||
|
canAddUsers = state.users.users.userCreatePermission;
|
||||||
|
}
|
||||||
return {
|
return {
|
||||||
userEntries,
|
userEntries,
|
||||||
error: state.users.error,
|
error,
|
||||||
canAddUsers: state.users.userCreatePermission
|
canAddUsers
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -16,6 +16,8 @@ export const ADD_USER = "scm/users/ADD";
|
|||||||
export const ADD_USER_SUCCESS = "scm/users/ADD_SUCCESS";
|
export const ADD_USER_SUCCESS = "scm/users/ADD_SUCCESS";
|
||||||
export const ADD_USER_FAILURE = "scm/users/ADD_FAILURE";
|
export const ADD_USER_FAILURE = "scm/users/ADD_FAILURE";
|
||||||
|
|
||||||
|
export const EDIT_USER = "scm/users/EDIT";
|
||||||
|
|
||||||
export const UPDATE_USER = "scm/users/UPDATE";
|
export const UPDATE_USER = "scm/users/UPDATE";
|
||||||
export const UPDATE_USER_SUCCESS = "scm/users/UPDATE_SUCCESS";
|
export const UPDATE_USER_SUCCESS = "scm/users/UPDATE_SUCCESS";
|
||||||
export const UPDATE_USER_FAILURE = "scm/users/UPDATE_FAILURE";
|
export const UPDATE_USER_FAILURE = "scm/users/UPDATE_FAILURE";
|
||||||
@@ -35,18 +37,13 @@ export function requestUsers() {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
export function failedToFetchUsers(url: string, err: Error) {
|
export function failedToFetchUsers(url: string, error: Error) {
|
||||||
return {
|
return {
|
||||||
type: FETCH_USERS_FAILURE,
|
type: FETCH_USERS_FAILURE,
|
||||||
payload: err,
|
payload: {
|
||||||
url
|
error,
|
||||||
};
|
url
|
||||||
}
|
}
|
||||||
|
|
||||||
function usersNotFound(url: string) {
|
|
||||||
return {
|
|
||||||
type: FETCH_USERS_NOTFOUND,
|
|
||||||
url
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -66,12 +63,9 @@ export function fetchUsers() {
|
|||||||
.then(data => {
|
.then(data => {
|
||||||
dispatch(fetchUsersSuccess(data));
|
dispatch(fetchUsersSuccess(data));
|
||||||
})
|
})
|
||||||
.catch(err => {
|
.catch(cause => {
|
||||||
if (err === NOT_FOUND_ERROR) {
|
const error = new Error(`could not fetch users: ${cause.message}`);
|
||||||
dispatch(usersNotFound(USERS_URL));
|
dispatch(failedToFetchUsers(USERS_URL, error));
|
||||||
} else {
|
|
||||||
dispatch(failedToFetchUsers(USERS_URL, err));
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@@ -107,12 +101,9 @@ export function fetchUser(name: string) {
|
|||||||
.then(data => {
|
.then(data => {
|
||||||
dispatch(fetchUserSuccess(data));
|
dispatch(fetchUserSuccess(data));
|
||||||
})
|
})
|
||||||
.catch(err => {
|
.catch(cause => {
|
||||||
if (err === NOT_FOUND_ERROR) {
|
const error = new Error(`could not fetch user: ${cause.message}`);
|
||||||
dispatch(usersNotFound(userUrl));
|
dispatch(failedToFetchUsers(USERS_URL, error));
|
||||||
} else {
|
|
||||||
dispatch(failedToFetchUsers(userUrl, err));
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@@ -178,20 +169,24 @@ export function updateUser(user: User) {
|
|||||||
return apiClient
|
return apiClient
|
||||||
.putWithContentType(user._links.update.href, user, CONTENT_TYPE_USER)
|
.putWithContentType(user._links.update.href, user, CONTENT_TYPE_USER)
|
||||||
.then(() => {
|
.then(() => {
|
||||||
dispatch(updateUserSuccess());
|
dispatch(updateUserSuccess(user));
|
||||||
dispatch(fetchUsers());
|
dispatch(fetchUsers());
|
||||||
})
|
})
|
||||||
.catch(err => dispatch(updateUserFailure(user, err)));
|
.catch(err => {
|
||||||
|
console.log(err)
|
||||||
|
dispatch(updateUserFailure(user, err))
|
||||||
|
});
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
function updateUserSuccess() {
|
function updateUserSuccess(user: User) {
|
||||||
return {
|
return {
|
||||||
type: UPDATE_USER_SUCCESS
|
type: UPDATE_USER_SUCCESS,
|
||||||
|
user
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
function updateUserFailure(user: User, error: Error) {
|
export function updateUserFailure(user: User, error: Error) {
|
||||||
return {
|
return {
|
||||||
type: UPDATE_USER_FAILURE,
|
type: UPDATE_USER_FAILURE,
|
||||||
payload: error,
|
payload: error,
|
||||||
@@ -206,7 +201,7 @@ export function requestDeleteUser(user: User) {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
function deleteUserSuccess(user: User) {
|
export function deleteUserSuccess(user: User) {
|
||||||
return {
|
return {
|
||||||
type: DELETE_USER_SUCCESS,
|
type: DELETE_USER_SUCCESS,
|
||||||
payload: user
|
payload: user
|
||||||
@@ -232,7 +227,12 @@ export function deleteUser(user: User) {
|
|||||||
dispatch(deleteUserSuccess(user));
|
dispatch(deleteUserSuccess(user));
|
||||||
dispatch(fetchUsers());
|
dispatch(fetchUsers());
|
||||||
})
|
})
|
||||||
.catch(err => dispatch(deleteUserFailure(user, err)));
|
.catch(cause => {
|
||||||
|
const error = new Error(
|
||||||
|
`could not delete user ${user.name}: ${cause.message}`
|
||||||
|
);
|
||||||
|
dispatch(deleteUserFailure(user, error));
|
||||||
|
});
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -271,6 +271,21 @@ function extractUsersByNames(
|
|||||||
}
|
}
|
||||||
return usersByNames;
|
return usersByNames;
|
||||||
}
|
}
|
||||||
|
function deleteUserInUsersByNames(users: {}, userName: any) {
|
||||||
|
let newUsers = {};
|
||||||
|
for (let username in users) {
|
||||||
|
if (username != userName) newUsers[username] = users[username];
|
||||||
|
}
|
||||||
|
return newUsers;
|
||||||
|
}
|
||||||
|
|
||||||
|
function deleteUserInEntries(users: [], userName: any) {
|
||||||
|
let newUsers = [];
|
||||||
|
for (let user of users) {
|
||||||
|
if (user != userName) newUsers.push(user);
|
||||||
|
}
|
||||||
|
return newUsers;
|
||||||
|
}
|
||||||
|
|
||||||
const reduceUsersByNames = (
|
const reduceUsersByNames = (
|
||||||
state: any,
|
state: any,
|
||||||
@@ -292,8 +307,10 @@ export default function reducer(state: any = {}, action: any = {}) {
|
|||||||
switch (action.type) {
|
switch (action.type) {
|
||||||
case FETCH_USERS:
|
case FETCH_USERS:
|
||||||
return {
|
return {
|
||||||
loading: true,
|
...state,
|
||||||
error: null
|
users: {
|
||||||
|
loading: true
|
||||||
|
}
|
||||||
};
|
};
|
||||||
case DELETE_USER:
|
case DELETE_USER:
|
||||||
return reduceUsersByNames(state, action.payload.name, {
|
return reduceUsersByNames(state, action.payload.name, {
|
||||||
@@ -340,14 +357,43 @@ export default function reducer(state: any = {}, action: any = {}) {
|
|||||||
},
|
},
|
||||||
usersByNames: ubn
|
usersByNames: ubn
|
||||||
};
|
};
|
||||||
|
case DELETE_USER_SUCCESS:
|
||||||
|
const newUserByNames = deleteUserInUsersByNames(state.usersByNames, [
|
||||||
|
action.payload.name
|
||||||
|
]);
|
||||||
|
const newUserEntries = deleteUserInEntries(state.users.entries, [
|
||||||
|
action.payload.name
|
||||||
|
]);
|
||||||
|
return {
|
||||||
|
...state,
|
||||||
|
users: {
|
||||||
|
...state.users,
|
||||||
|
entries: newUserEntries
|
||||||
|
},
|
||||||
|
usersByNames: newUserByNames
|
||||||
|
};
|
||||||
case FETCH_USERS_FAILURE:
|
case FETCH_USERS_FAILURE:
|
||||||
|
return {
|
||||||
|
...state,
|
||||||
|
users: {
|
||||||
|
...state.users,
|
||||||
|
loading: false,
|
||||||
|
error: action.payload.error
|
||||||
|
}
|
||||||
|
};
|
||||||
case DELETE_USER_FAILURE:
|
case DELETE_USER_FAILURE:
|
||||||
return reduceUsersByNames(state, action.payload.user.name, {
|
const newState = reduceUsersByNames(state, action.payload.user.name, {
|
||||||
loading: false,
|
loading: false,
|
||||||
error: action.payload.error,
|
error: action.payload.error,
|
||||||
entry: action.payload.user
|
entry: action.payload.user
|
||||||
});
|
});
|
||||||
|
return {
|
||||||
|
...newState,
|
||||||
|
users: {
|
||||||
|
...newState.users,
|
||||||
|
error: action.payload.error
|
||||||
|
}
|
||||||
|
};
|
||||||
case ADD_USER:
|
case ADD_USER:
|
||||||
return {
|
return {
|
||||||
...state,
|
...state,
|
||||||
@@ -363,9 +409,17 @@ export default function reducer(state: any = {}, action: any = {}) {
|
|||||||
users: {
|
users: {
|
||||||
...state.users,
|
...state.users,
|
||||||
loading: false,
|
loading: false,
|
||||||
error: null
|
error: null
|
||||||
|
}
|
||||||
|
};
|
||||||
|
case ADD_USER_SUCCESS:
|
||||||
|
return {
|
||||||
|
...state,
|
||||||
|
users: {
|
||||||
|
...state.users,
|
||||||
|
loading: false,
|
||||||
|
error: null
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
case ADD_USER_FAILURE:
|
case ADD_USER_FAILURE:
|
||||||
return {
|
return {
|
||||||
@@ -376,6 +430,31 @@ export default function reducer(state: any = {}, action: any = {}) {
|
|||||||
error: action.payload
|
error: action.payload
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
case UPDATE_USER:
|
||||||
|
return {
|
||||||
|
...state,
|
||||||
|
usersByNames: {
|
||||||
|
...state.usersByNames,
|
||||||
|
[action.user.name]: {
|
||||||
|
loading: true,
|
||||||
|
error: null,
|
||||||
|
entry: action.user
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
case UPDATE_USER_SUCCESS:
|
||||||
|
return {
|
||||||
|
...state,
|
||||||
|
usersByNames: {
|
||||||
|
...state.usersByNames,
|
||||||
|
[action.user.name]: {
|
||||||
|
loading: false,
|
||||||
|
error: null,
|
||||||
|
entry: action.user
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return state;
|
return state;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -16,6 +16,7 @@ import {
|
|||||||
UPDATE_USER,
|
UPDATE_USER,
|
||||||
UPDATE_USER_FAILURE,
|
UPDATE_USER_FAILURE,
|
||||||
UPDATE_USER_SUCCESS,
|
UPDATE_USER_SUCCESS,
|
||||||
|
EDIT_USER,
|
||||||
requestDeleteUser,
|
requestDeleteUser,
|
||||||
deleteUserFailure,
|
deleteUserFailure,
|
||||||
DELETE_USER,
|
DELETE_USER,
|
||||||
@@ -26,7 +27,10 @@ import {
|
|||||||
fetchUsersSuccess,
|
fetchUsersSuccess,
|
||||||
requestAddUser,
|
requestAddUser,
|
||||||
addUserSuccess,
|
addUserSuccess,
|
||||||
addUserFailure
|
addUserFailure,
|
||||||
|
updateUserFailure,
|
||||||
|
deleteUserSuccess,
|
||||||
|
failedToFetchUsers
|
||||||
} from "./users";
|
} from "./users";
|
||||||
|
|
||||||
import reducer from "./users";
|
import reducer from "./users";
|
||||||
@@ -261,10 +265,10 @@ describe("users fetch()", () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
describe("users reducer", () => {
|
describe("users reducer", () => {
|
||||||
test("should update state correctly according to FETCH_USERS action", () => {
|
it("should update state correctly according to FETCH_USERS action", () => {
|
||||||
const newState = reducer({}, requestUsers());
|
const newState = reducer({}, requestUsers());
|
||||||
expect(newState.loading).toBeTruthy();
|
expect(newState.users.loading).toBeTruthy();
|
||||||
expect(newState.error).toBeNull();
|
expect(newState.users.error).toBeFalsy();
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should update state correctly according to FETCH_USERS_SUCCESS action", () => {
|
it("should update state correctly according to FETCH_USERS_SUCCESS action", () => {
|
||||||
@@ -273,7 +277,8 @@ describe("users reducer", () => {
|
|||||||
expect(newState.users).toEqual({
|
expect(newState.users).toEqual({
|
||||||
entries: ["zaphod", "ford"],
|
entries: ["zaphod", "ford"],
|
||||||
error: null,
|
error: null,
|
||||||
loading: false
|
loading: false,
|
||||||
|
userCreatePermission: true
|
||||||
});
|
});
|
||||||
|
|
||||||
expect(newState.usersByNames).toEqual({
|
expect(newState.usersByNames).toEqual({
|
||||||
@@ -286,7 +291,7 @@ describe("users reducer", () => {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should update state correctly according to DELETE_USER action", () => {
|
test("should update state correctly according to DELETE_USER action", () => {
|
||||||
const state = {
|
const state = {
|
||||||
usersByNames: {
|
usersByNames: {
|
||||||
zaphod: {
|
zaphod: {
|
||||||
|
|||||||
Reference in New Issue
Block a user