Fixed merge bugs

This commit is contained in:
Philipp Czora
2018-07-19 12:38:26 +02:00
3 changed files with 133 additions and 43 deletions

View File

@@ -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
}; };
}; };

View File

@@ -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;
} }

View File

@@ -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: {