mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-10 15:35:49 +01:00
Merged branches
This commit is contained in:
@@ -2,7 +2,7 @@
|
||||
import { apiClient } from "../../apiclient";
|
||||
import type { User } from "../types/User";
|
||||
import type { UserEntry } from "../types/UserEntry";
|
||||
import { Dispatch } from "redux";
|
||||
import { combineReducers, Dispatch } from "redux";
|
||||
import type { Action } from "../../types/Action";
|
||||
import type { PageCollectionStateSlice } from "../../types/Collection";
|
||||
|
||||
@@ -22,7 +22,7 @@ export const MODIFY_USER_PENDING = "scm/users/MODIFY_USER_PENDING";
|
||||
export const MODIFY_USER_SUCCESS = "scm/users/MODIFY_USER_SUCCESS";
|
||||
export const MODIFY_USER_FAILURE = "scm/users/MODIFY_USER_FAILURE";
|
||||
|
||||
export const DELETE_USER = "scm/users/DELETE";
|
||||
export const DELETE_USER_PENDING = "scm/users/DELETE_PENDING";
|
||||
export const DELETE_USER_SUCCESS = "scm/users/DELETE_SUCCESS";
|
||||
export const DELETE_USER_FAILURE = "scm/users/DELETE_FAILURE";
|
||||
|
||||
@@ -30,6 +30,8 @@ const USERS_URL = "users";
|
||||
|
||||
const CONTENT_TYPE_USER = "application/vnd.scmm-user+json;v=2";
|
||||
|
||||
//TODO i18n
|
||||
|
||||
//fetch users
|
||||
|
||||
export function fetchUsers() {
|
||||
@@ -241,7 +243,7 @@ export function deleteUser(user: User, callback?: () => void) {
|
||||
|
||||
export function deleteUserPending(user: User): Action {
|
||||
return {
|
||||
type: DELETE_USER,
|
||||
type: DELETE_USER_PENDING,
|
||||
payload: user
|
||||
};
|
||||
}
|
||||
@@ -300,7 +302,8 @@ function extractUsersByNames(
|
||||
}
|
||||
return usersByNames;
|
||||
}
|
||||
function deleteUserInUsersByNames(users: {}, userName: any) {
|
||||
|
||||
function deleteUserInUsersByNames(users: {}, userName: string) {
|
||||
let newUsers = {};
|
||||
for (let username in users) {
|
||||
if (username !== userName) newUsers[username] = users[username];
|
||||
@@ -308,7 +311,7 @@ function deleteUserInUsersByNames(users: {}, userName: any) {
|
||||
return newUsers;
|
||||
}
|
||||
|
||||
function deleteUserInEntries(users: [], userName: any) {
|
||||
function deleteUserInEntries(users: [], userName: string) {
|
||||
let newUsers = [];
|
||||
for (let user of users) {
|
||||
if (user !== userName) newUsers.push(user);
|
||||
@@ -318,130 +321,87 @@ function deleteUserInEntries(users: [], userName: any) {
|
||||
|
||||
const reducerByName = (state: any, username: string, newUserState: any) => {
|
||||
const newUsersByNames = {
|
||||
...state.byNames,
|
||||
...state,
|
||||
[username]: newUserState
|
||||
};
|
||||
|
||||
return {
|
||||
...state,
|
||||
byNames: newUsersByNames
|
||||
};
|
||||
return newUsersByNames;
|
||||
};
|
||||
|
||||
export default function reducer(state: any = {}, action: any = {}) {
|
||||
function listReducer(state: any = {}, action: any = {}) {
|
||||
switch (action.type) {
|
||||
// fetch user list cases
|
||||
// Fetch all users actions
|
||||
case FETCH_USERS_PENDING:
|
||||
return {
|
||||
...state,
|
||||
list: {
|
||||
loading: true
|
||||
loading: true
|
||||
};
|
||||
case FETCH_USERS_SUCCESS:
|
||||
const users = action.payload._embedded.users;
|
||||
const userNames = users.map(user => user.name);
|
||||
return {
|
||||
...state,
|
||||
error: null,
|
||||
entries: userNames,
|
||||
loading: false,
|
||||
entry: {
|
||||
userCreatePermission: action.payload._links.create ? true : false,
|
||||
page: action.payload.page,
|
||||
pageTotal: action.payload.pageTotal,
|
||||
_links: action.payload._links
|
||||
}
|
||||
};
|
||||
case FETCH_USERS_FAILURE:
|
||||
return {
|
||||
...state,
|
||||
loading: false,
|
||||
error: action.payload.error
|
||||
};
|
||||
// Delete single user actions
|
||||
case DELETE_USER_SUCCESS:
|
||||
const newUserEntries = deleteUserInEntries(
|
||||
state.entries,
|
||||
action.payload.name
|
||||
);
|
||||
return {
|
||||
...state,
|
||||
entries: newUserEntries
|
||||
};
|
||||
default:
|
||||
return state;
|
||||
}
|
||||
}
|
||||
|
||||
function byNamesReducer(state: any = {}, action: any = {}) {
|
||||
switch (action.type) {
|
||||
// Fetch all users actions
|
||||
case FETCH_USERS_SUCCESS:
|
||||
const users = action.payload._embedded.users;
|
||||
const userNames = users.map(user => user.name);
|
||||
const byNames = extractUsersByNames(users, userNames, state.byNames);
|
||||
return {
|
||||
...state,
|
||||
list: {
|
||||
error: null,
|
||||
loading: false,
|
||||
entries: userNames,
|
||||
entry: {
|
||||
userCreatePermission: action.payload._links.create ? true : false,
|
||||
page: action.payload.page,
|
||||
pageTotal: action.payload.pageTotal,
|
||||
_links: action.payload._links
|
||||
}
|
||||
},
|
||||
byNames
|
||||
...byNames
|
||||
};
|
||||
case FETCH_USERS_FAILURE:
|
||||
return {
|
||||
...state,
|
||||
list: {
|
||||
...state.users,
|
||||
loading: false,
|
||||
error: action.payload.error
|
||||
}
|
||||
};
|
||||
// Fetch single user cases
|
||||
|
||||
// Fetch single user actions
|
||||
case FETCH_USER_PENDING:
|
||||
return reducerByName(state, action.payload.name, {
|
||||
loading: true,
|
||||
error: null
|
||||
});
|
||||
|
||||
case FETCH_USER_SUCCESS:
|
||||
return reducerByName(state, action.payload.name, {
|
||||
loading: false,
|
||||
error: null,
|
||||
entry: action.payload
|
||||
});
|
||||
|
||||
case FETCH_USER_FAILURE:
|
||||
return reducerByName(state, action.payload.username, {
|
||||
loading: false,
|
||||
error: action.payload.error
|
||||
});
|
||||
|
||||
// Delete single user cases
|
||||
case DELETE_USER:
|
||||
return reducerByName(state, action.payload.name, {
|
||||
loading: true,
|
||||
error: null,
|
||||
entry: action.payload
|
||||
});
|
||||
|
||||
case DELETE_USER_SUCCESS:
|
||||
const newUserByNames = deleteUserInUsersByNames(state.byNames, [
|
||||
action.payload.name
|
||||
]);
|
||||
const newUserEntries = deleteUserInEntries(state.list.entries, [
|
||||
action.payload.name
|
||||
]);
|
||||
return {
|
||||
...state,
|
||||
list: {
|
||||
...state.list,
|
||||
entries: newUserEntries
|
||||
},
|
||||
byNames: newUserByNames
|
||||
};
|
||||
|
||||
case DELETE_USER_FAILURE:
|
||||
return reducerByName(state, action.payload.user.name, {
|
||||
loading: false,
|
||||
error: action.payload.error,
|
||||
entry: action.payload.user
|
||||
});
|
||||
|
||||
// Add single user cases
|
||||
case CREATE_USER_PENDING:
|
||||
return {
|
||||
...state,
|
||||
create: {
|
||||
loading: true
|
||||
}
|
||||
};
|
||||
case CREATE_USER_SUCCESS:
|
||||
return {
|
||||
...state,
|
||||
create: {
|
||||
loading: false
|
||||
}
|
||||
};
|
||||
case CREATE_USER_FAILURE:
|
||||
return {
|
||||
...state,
|
||||
create: {
|
||||
loading: false,
|
||||
error: action.payload
|
||||
}
|
||||
};
|
||||
|
||||
// Update single user cases
|
||||
// Update single user actions
|
||||
case MODIFY_USER_PENDING:
|
||||
return reducerByName(state, action.payload.name, {
|
||||
loading: true
|
||||
@@ -454,6 +414,27 @@ export default function reducer(state: any = {}, action: any = {}) {
|
||||
return reducerByName(state, action.payload.user.name, {
|
||||
error: action.payload.error
|
||||
});
|
||||
|
||||
// Delete single user actions
|
||||
case DELETE_USER_PENDING:
|
||||
return reducerByName(state, action.payload.name, {
|
||||
loading: true,
|
||||
error: null,
|
||||
entry: action.payload
|
||||
});
|
||||
case DELETE_USER_SUCCESS:
|
||||
const newUserByNames = deleteUserInUsersByNames(
|
||||
state,
|
||||
action.payload.name
|
||||
);
|
||||
return newUserByNames;
|
||||
|
||||
case DELETE_USER_FAILURE:
|
||||
return reducerByName(state, action.payload.user.name, {
|
||||
loading: false,
|
||||
error: action.payload.error,
|
||||
entry: action.payload.user
|
||||
});
|
||||
default:
|
||||
return state;
|
||||
}
|
||||
@@ -489,3 +470,31 @@ export const isPermittedToCreateUsers = (state: Object): boolean => {
|
||||
}
|
||||
return false;
|
||||
};
|
||||
function createReducer(state: any = {}, action: any = {}) {
|
||||
switch (action.type) {
|
||||
case CREATE_USER_PENDING:
|
||||
return {
|
||||
...state,
|
||||
loading: true
|
||||
};
|
||||
case CREATE_USER_SUCCESS:
|
||||
return {
|
||||
...state,
|
||||
loading: false
|
||||
};
|
||||
case CREATE_USER_FAILURE:
|
||||
return {
|
||||
...state,
|
||||
loading: false,
|
||||
error: action.payload
|
||||
};
|
||||
default:
|
||||
return state;
|
||||
}
|
||||
}
|
||||
|
||||
export default combineReducers({
|
||||
list: listReducer,
|
||||
byNames: byNamesReducer,
|
||||
create: createReducer
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user