asynqmon/ui/src/reducers/tasksReducer.ts

1162 lines
28 KiB
TypeScript
Raw Normal View History

2020-11-24 22:54:00 +08:00
import {
LIST_ACTIVE_TASKS_BEGIN,
LIST_ACTIVE_TASKS_SUCCESS,
LIST_ACTIVE_TASKS_ERROR,
TasksActionTypes,
LIST_PENDING_TASKS_BEGIN,
LIST_PENDING_TASKS_SUCCESS,
LIST_PENDING_TASKS_ERROR,
LIST_SCHEDULED_TASKS_BEGIN,
LIST_SCHEDULED_TASKS_SUCCESS,
LIST_SCHEDULED_TASKS_ERROR,
LIST_RETRY_TASKS_BEGIN,
LIST_RETRY_TASKS_SUCCESS,
LIST_RETRY_TASKS_ERROR,
LIST_ARCHIVED_TASKS_BEGIN,
LIST_ARCHIVED_TASKS_SUCCESS,
LIST_ARCHIVED_TASKS_ERROR,
CANCEL_ACTIVE_TASK_BEGIN,
CANCEL_ACTIVE_TASK_SUCCESS,
CANCEL_ACTIVE_TASK_ERROR,
DELETE_RETRY_TASK_BEGIN,
DELETE_RETRY_TASK_SUCCESS,
DELETE_RETRY_TASK_ERROR,
DELETE_SCHEDULED_TASK_BEGIN,
DELETE_SCHEDULED_TASK_SUCCESS,
DELETE_SCHEDULED_TASK_ERROR,
DELETE_ARCHIVED_TASK_BEGIN,
DELETE_ARCHIVED_TASK_SUCCESS,
DELETE_ARCHIVED_TASK_ERROR,
BATCH_DELETE_ARCHIVED_TASKS_BEGIN,
BATCH_DELETE_ARCHIVED_TASKS_SUCCESS,
BATCH_DELETE_ARCHIVED_TASKS_ERROR,
RUN_ARCHIVED_TASK_BEGIN,
RUN_ARCHIVED_TASK_SUCCESS,
RUN_ARCHIVED_TASK_ERROR,
BATCH_RUN_ARCHIVED_TASKS_BEGIN,
BATCH_RUN_ARCHIVED_TASKS_ERROR,
BATCH_RUN_ARCHIVED_TASKS_SUCCESS,
DELETE_ALL_ARCHIVED_TASKS_BEGIN,
DELETE_ALL_ARCHIVED_TASKS_SUCCESS,
DELETE_ALL_ARCHIVED_TASKS_ERROR,
RUN_ALL_ARCHIVED_TASKS_BEGIN,
RUN_ALL_ARCHIVED_TASKS_ERROR,
RUN_ALL_ARCHIVED_TASKS_SUCCESS,
BATCH_DELETE_RETRY_TASKS_ERROR,
BATCH_RUN_RETRY_TASKS_ERROR,
BATCH_DELETE_RETRY_TASKS_SUCCESS,
BATCH_RUN_RETRY_TASKS_SUCCESS,
BATCH_DELETE_RETRY_TASKS_BEGIN,
BATCH_RUN_RETRY_TASKS_BEGIN,
DELETE_ALL_RETRY_TASKS_ERROR,
RUN_ALL_RETRY_TASKS_ERROR,
DELETE_ALL_RETRY_TASKS_SUCCESS,
RUN_ALL_RETRY_TASKS_SUCCESS,
DELETE_ALL_RETRY_TASKS_BEGIN,
RUN_ALL_RETRY_TASKS_BEGIN,
BATCH_DELETE_SCHEDULED_TASKS_ERROR,
BATCH_RUN_SCHEDULED_TASKS_ERROR,
BATCH_DELETE_SCHEDULED_TASKS_SUCCESS,
BATCH_RUN_SCHEDULED_TASKS_SUCCESS,
BATCH_DELETE_SCHEDULED_TASKS_BEGIN,
BATCH_RUN_SCHEDULED_TASKS_BEGIN,
DELETE_ALL_SCHEDULED_TASKS_ERROR,
RUN_ALL_SCHEDULED_TASKS_ERROR,
DELETE_ALL_SCHEDULED_TASKS_SUCCESS,
RUN_ALL_SCHEDULED_TASKS_SUCCESS,
DELETE_ALL_SCHEDULED_TASKS_BEGIN,
RUN_ALL_SCHEDULED_TASKS_BEGIN,
RUN_RETRY_TASK_BEGIN,
RUN_RETRY_TASK_SUCCESS,
RUN_RETRY_TASK_ERROR,
RUN_SCHEDULED_TASK_BEGIN,
RUN_SCHEDULED_TASK_SUCCESS,
RUN_SCHEDULED_TASK_ERROR,
ARCHIVE_SCHEDULED_TASK_BEGIN,
ARCHIVE_SCHEDULED_TASK_SUCCESS,
ARCHIVE_SCHEDULED_TASK_ERROR,
ARCHIVE_ALL_SCHEDULED_TASKS_BEGIN,
ARCHIVE_ALL_SCHEDULED_TASKS_SUCCESS,
ARCHIVE_ALL_SCHEDULED_TASKS_ERROR,
BATCH_ARCHIVE_SCHEDULED_TASKS_BEGIN,
BATCH_ARCHIVE_SCHEDULED_TASKS_ERROR,
BATCH_ARCHIVE_SCHEDULED_TASKS_SUCCESS,
ARCHIVE_RETRY_TASK_BEGIN,
ARCHIVE_RETRY_TASK_SUCCESS,
ARCHIVE_RETRY_TASK_ERROR,
ARCHIVE_ALL_RETRY_TASKS_BEGIN,
ARCHIVE_ALL_RETRY_TASKS_SUCCESS,
ARCHIVE_ALL_RETRY_TASKS_ERROR,
BATCH_ARCHIVE_RETRY_TASKS_SUCCESS,
BATCH_ARCHIVE_RETRY_TASKS_BEGIN,
BATCH_ARCHIVE_RETRY_TASKS_ERROR,
2020-12-23 22:59:44 +08:00
BATCH_CANCEL_ACTIVE_TASKS_BEGIN,
BATCH_CANCEL_ACTIVE_TASKS_SUCCESS,
BATCH_CANCEL_ACTIVE_TASKS_ERROR,
CANCEL_ALL_ACTIVE_TASKS_BEGIN,
CANCEL_ALL_ACTIVE_TASKS_SUCCESS,
CANCEL_ALL_ACTIVE_TASKS_ERROR,
ARCHIVE_PENDING_TASK_BEGIN,
DELETE_PENDING_TASK_BEGIN,
ARCHIVE_PENDING_TASK_SUCCESS,
DELETE_PENDING_TASK_SUCCESS,
ARCHIVE_PENDING_TASK_ERROR,
DELETE_PENDING_TASK_ERROR,
ARCHIVE_ALL_PENDING_TASKS_BEGIN,
DELETE_ALL_PENDING_TASKS_BEGIN,
ARCHIVE_ALL_PENDING_TASKS_SUCCESS,
DELETE_ALL_PENDING_TASKS_SUCCESS,
ARCHIVE_ALL_PENDING_TASKS_ERROR,
DELETE_ALL_PENDING_TASKS_ERROR,
BATCH_ARCHIVE_PENDING_TASKS_BEGIN,
BATCH_DELETE_PENDING_TASKS_BEGIN,
BATCH_ARCHIVE_PENDING_TASKS_SUCCESS,
BATCH_DELETE_PENDING_TASKS_SUCCESS,
BATCH_ARCHIVE_PENDING_TASKS_ERROR,
BATCH_DELETE_PENDING_TASKS_ERROR,
2020-11-24 22:54:00 +08:00
} from "../actions/tasksActions";
import {
ActiveTask,
ArchivedTask,
2020-11-24 22:54:00 +08:00
PendingTask,
RetryTask,
ScheduledTask,
} from "../api";
export interface ActiveTaskExtended extends ActiveTask {
// Indicates that a request has been sent for this
// task and awaiting for a response.
requestPending: boolean;
// Incidates that a cancelation signal has been
// published for this task.
canceling: boolean;
}
export interface PendingTaskExtended extends PendingTask {
// Indicates that a request has been sent for this
// task and awaiting for a response.
requestPending: boolean;
}
export interface ScheduledTaskExtended extends ScheduledTask {
// Indicates that a request has been sent for this
// task and awaiting for a response.
requestPending: boolean;
}
export interface RetryTaskExtended extends RetryTask {
// Indicates that a request has been sent for this
// task and awaiting for a response.
requestPending: boolean;
}
export interface ArchivedTaskExtended extends ArchivedTask {
// Indicates that a request has been sent for this
// task and awaiting for a response.
requestPending: boolean;
}
2020-11-24 22:54:00 +08:00
interface TasksState {
activeTasks: {
loading: boolean;
2020-12-23 22:59:44 +08:00
batchActionPending: boolean;
allActionPending: boolean;
2020-11-24 22:54:00 +08:00
error: string;
data: ActiveTaskExtended[];
2020-11-24 22:54:00 +08:00
};
pendingTasks: {
loading: boolean;
batchActionPending: boolean;
allActionPending: boolean;
2020-11-24 22:54:00 +08:00
error: string;
data: PendingTaskExtended[];
2020-11-24 22:54:00 +08:00
};
scheduledTasks: {
loading: boolean;
2020-12-19 04:48:05 +08:00
batchActionPending: boolean;
allActionPending: boolean;
2020-11-24 22:54:00 +08:00
error: string;
data: ScheduledTaskExtended[];
2020-11-24 22:54:00 +08:00
};
retryTasks: {
loading: boolean;
2020-12-19 04:48:05 +08:00
batchActionPending: boolean;
allActionPending: boolean;
2020-11-24 22:54:00 +08:00
error: string;
data: RetryTaskExtended[];
2020-11-24 22:54:00 +08:00
};
archivedTasks: {
2020-11-24 22:54:00 +08:00
loading: boolean;
batchActionPending: boolean;
allActionPending: boolean;
2020-11-24 22:54:00 +08:00
error: string;
data: ArchivedTaskExtended[];
2020-11-24 22:54:00 +08:00
};
}
const initialState: TasksState = {
activeTasks: {
loading: false,
2020-12-23 22:59:44 +08:00
batchActionPending: false,
allActionPending: false,
2020-11-24 22:54:00 +08:00
error: "",
data: [],
},
pendingTasks: {
loading: false,
batchActionPending: false,
allActionPending: false,
2020-11-24 22:54:00 +08:00
error: "",
data: [],
},
scheduledTasks: {
loading: false,
2020-12-19 04:48:05 +08:00
batchActionPending: false,
allActionPending: false,
2020-11-24 22:54:00 +08:00
error: "",
data: [],
},
retryTasks: {
loading: false,
2020-12-19 04:48:05 +08:00
batchActionPending: false,
allActionPending: false,
2020-11-24 22:54:00 +08:00
error: "",
data: [],
},
archivedTasks: {
2020-11-24 22:54:00 +08:00
loading: false,
batchActionPending: false,
allActionPending: false,
2020-11-24 22:54:00 +08:00
error: "",
data: [],
},
};
function tasksReducer(
state = initialState,
action: TasksActionTypes
): TasksState {
switch (action.type) {
case LIST_ACTIVE_TASKS_BEGIN:
return {
...state,
activeTasks: {
...state.activeTasks,
loading: true,
},
};
case LIST_ACTIVE_TASKS_SUCCESS:
return {
...state,
activeTasks: {
2020-12-23 22:59:44 +08:00
...state.activeTasks,
2020-11-24 22:54:00 +08:00
loading: false,
error: "",
data: action.payload.tasks.map((task) => ({
...task,
canceling: false,
requestPending: false,
})),
2020-11-24 22:54:00 +08:00
},
};
case LIST_ACTIVE_TASKS_ERROR:
return {
...state,
activeTasks: {
...state.activeTasks,
loading: false,
error: action.error,
2021-01-27 13:25:42 +08:00
data: [],
2020-11-24 22:54:00 +08:00
},
};
case LIST_PENDING_TASKS_BEGIN:
return {
...state,
pendingTasks: {
...state.pendingTasks,
loading: true,
},
};
case LIST_PENDING_TASKS_SUCCESS:
return {
...state,
pendingTasks: {
...state.pendingTasks,
2020-11-24 22:54:00 +08:00
loading: false,
error: "",
data: action.payload.tasks.map((task) => ({
...task,
requestPending: false,
})),
2020-11-24 22:54:00 +08:00
},
};
case LIST_PENDING_TASKS_ERROR:
return {
...state,
pendingTasks: {
...state.pendingTasks,
loading: false,
error: action.error,
2021-01-27 13:25:42 +08:00
data: [],
2020-11-24 22:54:00 +08:00
},
};
case LIST_SCHEDULED_TASKS_BEGIN:
return {
...state,
scheduledTasks: {
...state.scheduledTasks,
loading: true,
},
};
case LIST_SCHEDULED_TASKS_SUCCESS:
return {
...state,
scheduledTasks: {
2020-12-19 04:48:05 +08:00
...state.scheduledTasks,
2020-11-24 22:54:00 +08:00
loading: false,
error: "",
data: action.payload.tasks.map((task) => ({
...task,
requestPending: false,
})),
2020-11-24 22:54:00 +08:00
},
};
case LIST_SCHEDULED_TASKS_ERROR:
return {
...state,
scheduledTasks: {
...state.scheduledTasks,
loading: false,
error: action.error,
2021-01-27 13:25:42 +08:00
data: [],
2020-11-24 22:54:00 +08:00
},
};
case LIST_RETRY_TASKS_BEGIN:
return {
...state,
retryTasks: {
...state.retryTasks,
loading: true,
},
};
case LIST_RETRY_TASKS_SUCCESS:
return {
...state,
retryTasks: {
2020-12-19 04:48:05 +08:00
...state.retryTasks,
2020-11-24 22:54:00 +08:00
loading: false,
error: "",
data: action.payload.tasks.map((task) => ({
...task,
requestPending: false,
})),
2020-11-24 22:54:00 +08:00
},
};
case LIST_RETRY_TASKS_ERROR:
return {
...state,
retryTasks: {
...state.retryTasks,
loading: false,
error: action.error,
2021-01-27 13:25:42 +08:00
data: [],
2020-11-24 22:54:00 +08:00
},
};
case LIST_ARCHIVED_TASKS_BEGIN:
2020-11-24 22:54:00 +08:00
return {
...state,
archivedTasks: {
...state.archivedTasks,
2020-11-24 22:54:00 +08:00
loading: true,
},
};
case LIST_ARCHIVED_TASKS_SUCCESS:
2020-11-24 22:54:00 +08:00
return {
...state,
archivedTasks: {
...state.archivedTasks,
2020-11-24 22:54:00 +08:00
loading: false,
error: "",
data: action.payload.tasks.map((task) => ({
...task,
requestPending: false,
})),
2020-11-24 22:54:00 +08:00
},
};
case LIST_ARCHIVED_TASKS_ERROR:
2020-11-24 22:54:00 +08:00
return {
...state,
archivedTasks: {
...state.archivedTasks,
2020-11-24 22:54:00 +08:00
loading: false,
error: action.error,
2021-01-27 13:25:42 +08:00
data: [],
2020-11-24 22:54:00 +08:00
},
};
case CANCEL_ACTIVE_TASK_BEGIN: {
const newData = state.activeTasks.data.map((task) => {
if (task.id !== action.taskId) {
return task;
}
return { ...task, requestPending: true };
});
return {
...state,
activeTasks: {
...state.activeTasks,
data: newData,
},
};
}
case CANCEL_ACTIVE_TASK_SUCCESS: {
const newData = state.activeTasks.data.map((task) => {
if (task.id !== action.taskId) {
return task;
}
return { ...task, requestPending: false, canceling: true };
});
return {
...state,
activeTasks: {
...state.activeTasks,
data: newData,
},
};
}
case CANCEL_ACTIVE_TASK_ERROR:
const newData = state.activeTasks.data.map((task) => {
if (task.id !== action.taskId) {
return task;
}
return { ...task, requestPending: false };
});
return {
...state,
activeTasks: {
...state.activeTasks,
data: newData,
},
};
2020-12-23 22:59:44 +08:00
case BATCH_CANCEL_ACTIVE_TASKS_BEGIN: {
const newData = state.activeTasks.data.map((task) => {
if (!action.taskIds.includes(task.id)) {
return task;
}
return { ...task, requestPending: true };
});
return {
...state,
activeTasks: {
...state.activeTasks,
batchActionPending: true,
data: newData,
},
};
}
case BATCH_CANCEL_ACTIVE_TASKS_SUCCESS: {
const newData = state.activeTasks.data.map((task) => {
if (action.payload.canceled_ids.includes(task.id)) {
return { ...task, canceling: true, requestPending: false };
}
if (action.payload.error_ids.includes(task.id)) {
return { ...task, requestPending: false };
}
return task;
});
return {
...state,
activeTasks: {
...state.activeTasks,
batchActionPending: false,
data: newData,
},
};
}
case BATCH_CANCEL_ACTIVE_TASKS_ERROR: {
const newData = state.activeTasks.data.map((task) => {
return { ...task, requestPending: false };
});
return {
...state,
activeTasks: {
...state.activeTasks,
batchActionPending: false,
data: newData,
},
};
}
case CANCEL_ALL_ACTIVE_TASKS_BEGIN: {
const newData = state.activeTasks.data.map((task) => ({
...task,
requestPending: true,
}));
return {
...state,
activeTasks: {
...state.activeTasks,
allActionPending: true,
data: newData,
},
};
}
case CANCEL_ALL_ACTIVE_TASKS_SUCCESS: {
const newData = state.activeTasks.data.map((task) => ({
...task,
requestPending: false,
canceling: true,
}));
return {
...state,
activeTasks: {
...state.activeTasks,
allActionPending: false,
data: newData,
},
};
}
case CANCEL_ALL_ACTIVE_TASKS_ERROR: {
const newData = state.activeTasks.data.map((task) => ({
...task,
requestPending: false,
}));
return {
...state,
activeTasks: {
...state.activeTasks,
allActionPending: false,
data: newData,
},
};
}
case ARCHIVE_PENDING_TASK_BEGIN:
case DELETE_PENDING_TASK_BEGIN:
return {
...state,
pendingTasks: {
...state.pendingTasks,
data: state.pendingTasks.data.map((task) => {
if (task.key !== action.taskKey) {
return task;
}
return { ...task, requestPending: true };
}),
},
};
case ARCHIVE_PENDING_TASK_SUCCESS:
case DELETE_PENDING_TASK_SUCCESS:
return {
...state,
pendingTasks: {
...state.pendingTasks,
data: state.pendingTasks.data.filter(
(task) => task.key !== action.taskKey
),
},
};
case ARCHIVE_PENDING_TASK_ERROR:
case DELETE_PENDING_TASK_ERROR:
return {
...state,
pendingTasks: {
...state.pendingTasks,
data: state.pendingTasks.data.map((task) => {
if (task.key !== action.taskKey) {
return task;
}
return { ...task, requestPending: false };
}),
},
};
case ARCHIVE_ALL_PENDING_TASKS_BEGIN:
case DELETE_ALL_PENDING_TASKS_BEGIN:
return {
...state,
pendingTasks: {
...state.pendingTasks,
allActionPending: true,
},
};
case ARCHIVE_ALL_PENDING_TASKS_SUCCESS:
case DELETE_ALL_PENDING_TASKS_SUCCESS:
return {
...state,
pendingTasks: {
...state.pendingTasks,
allActionPending: false,
data: [],
},
};
case ARCHIVE_ALL_PENDING_TASKS_ERROR:
case DELETE_ALL_PENDING_TASKS_ERROR:
return {
...state,
pendingTasks: {
...state.pendingTasks,
allActionPending: false,
},
};
case BATCH_ARCHIVE_PENDING_TASKS_BEGIN:
case BATCH_DELETE_PENDING_TASKS_BEGIN:
return {
...state,
pendingTasks: {
...state.pendingTasks,
batchActionPending: true,
data: state.pendingTasks.data.map((task) => {
if (!action.taskKeys.includes(task.key)) {
return task;
}
return {
...task,
requestPending: true,
};
}),
},
};
case BATCH_ARCHIVE_PENDING_TASKS_SUCCESS: {
const newData = state.pendingTasks.data.filter(
(task) => !action.payload.archived_keys.includes(task.key)
);
return {
...state,
pendingTasks: {
...state.pendingTasks,
batchActionPending: false,
data: newData,
},
};
}
case BATCH_DELETE_PENDING_TASKS_SUCCESS: {
const newData = state.pendingTasks.data.filter(
(task) => !action.payload.deleted_keys.includes(task.key)
);
return {
...state,
pendingTasks: {
...state.pendingTasks,
batchActionPending: false,
data: newData,
},
};
}
case BATCH_ARCHIVE_PENDING_TASKS_ERROR:
case BATCH_DELETE_PENDING_TASKS_ERROR:
return {
...state,
pendingTasks: {
...state.pendingTasks,
batchActionPending: false,
data: state.pendingTasks.data.map((task) => {
if (!action.taskKeys.includes(task.key)) {
return task;
}
return {
...task,
requestPending: false,
};
}),
},
};
case RUN_SCHEDULED_TASK_BEGIN:
case ARCHIVE_SCHEDULED_TASK_BEGIN:
case DELETE_SCHEDULED_TASK_BEGIN:
return {
...state,
scheduledTasks: {
...state.scheduledTasks,
data: state.scheduledTasks.data.map((task) => {
if (task.key !== action.taskKey) {
return task;
}
return { ...task, requestPending: true };
}),
},
};
case RUN_SCHEDULED_TASK_SUCCESS:
case ARCHIVE_SCHEDULED_TASK_SUCCESS:
case DELETE_SCHEDULED_TASK_SUCCESS:
return {
...state,
scheduledTasks: {
...state.scheduledTasks,
data: state.scheduledTasks.data.filter(
(task) => task.key !== action.taskKey
),
},
};
case RUN_SCHEDULED_TASK_ERROR:
case ARCHIVE_SCHEDULED_TASK_ERROR:
case DELETE_SCHEDULED_TASK_ERROR:
return {
...state,
scheduledTasks: {
...state.scheduledTasks,
data: state.scheduledTasks.data.map((task) => {
if (task.key !== action.taskKey) {
return task;
}
return { ...task, requestPending: false };
}),
},
};
case RUN_ALL_SCHEDULED_TASKS_BEGIN:
case ARCHIVE_ALL_SCHEDULED_TASKS_BEGIN:
case DELETE_ALL_SCHEDULED_TASKS_BEGIN:
return {
...state,
scheduledTasks: {
...state.scheduledTasks,
allActionPending: true,
},
};
case RUN_ALL_SCHEDULED_TASKS_SUCCESS:
case ARCHIVE_ALL_SCHEDULED_TASKS_SUCCESS:
case DELETE_ALL_SCHEDULED_TASKS_SUCCESS:
return {
...state,
scheduledTasks: {
...state.scheduledTasks,
allActionPending: false,
data: [],
},
};
case RUN_ALL_SCHEDULED_TASKS_ERROR:
case ARCHIVE_ALL_SCHEDULED_TASKS_ERROR:
case DELETE_ALL_SCHEDULED_TASKS_ERROR:
return {
...state,
scheduledTasks: {
...state.scheduledTasks,
allActionPending: false,
},
};
case BATCH_RUN_SCHEDULED_TASKS_BEGIN:
case BATCH_ARCHIVE_SCHEDULED_TASKS_BEGIN:
case BATCH_DELETE_SCHEDULED_TASKS_BEGIN:
return {
...state,
scheduledTasks: {
...state.scheduledTasks,
batchActionPending: true,
data: state.scheduledTasks.data.map((task) => {
if (!action.taskKeys.includes(task.key)) {
return task;
}
return {
...task,
requestPending: true,
};
}),
},
};
case BATCH_RUN_SCHEDULED_TASKS_SUCCESS: {
const newData = state.scheduledTasks.data.filter(
(task) => !action.payload.pending_keys.includes(task.key)
);
return {
...state,
scheduledTasks: {
...state.scheduledTasks,
batchActionPending: false,
data: newData,
},
};
}
case BATCH_ARCHIVE_SCHEDULED_TASKS_SUCCESS: {
const newData = state.scheduledTasks.data.filter(
(task) => !action.payload.archived_keys.includes(task.key)
);
return {
...state,
scheduledTasks: {
...state.scheduledTasks,
batchActionPending: false,
data: newData,
},
};
}
case BATCH_DELETE_SCHEDULED_TASKS_SUCCESS: {
const newData = state.scheduledTasks.data.filter(
(task) => !action.payload.deleted_keys.includes(task.key)
);
return {
...state,
scheduledTasks: {
...state.scheduledTasks,
batchActionPending: false,
data: newData,
},
};
}
case BATCH_RUN_SCHEDULED_TASKS_ERROR:
case BATCH_ARCHIVE_SCHEDULED_TASKS_ERROR:
case BATCH_DELETE_SCHEDULED_TASKS_ERROR:
return {
...state,
scheduledTasks: {
...state.scheduledTasks,
batchActionPending: false,
data: state.scheduledTasks.data.map((task) => {
if (!action.taskKeys.includes(task.key)) {
return task;
}
return {
...task,
requestPending: false,
};
}),
},
};
case RUN_RETRY_TASK_BEGIN:
case ARCHIVE_RETRY_TASK_BEGIN:
case DELETE_RETRY_TASK_BEGIN:
return {
...state,
retryTasks: {
...state.retryTasks,
data: state.retryTasks.data.map((task) => {
if (task.key !== action.taskKey) {
return task;
}
return { ...task, requestPending: true };
}),
},
};
case RUN_RETRY_TASK_SUCCESS:
case ARCHIVE_RETRY_TASK_SUCCESS:
case DELETE_RETRY_TASK_SUCCESS:
return {
...state,
retryTasks: {
...state.retryTasks,
data: state.retryTasks.data.filter(
(task) => task.key !== action.taskKey
),
},
};
case RUN_RETRY_TASK_ERROR:
case ARCHIVE_RETRY_TASK_ERROR:
case DELETE_RETRY_TASK_ERROR:
return {
...state,
retryTasks: {
...state.retryTasks,
data: state.retryTasks.data.map((task) => {
if (task.key !== action.taskKey) {
return task;
}
return { ...task, requestPending: false };
}),
},
};
case RUN_ALL_RETRY_TASKS_BEGIN:
case ARCHIVE_ALL_RETRY_TASKS_BEGIN:
case DELETE_ALL_RETRY_TASKS_BEGIN:
return {
...state,
retryTasks: {
...state.retryTasks,
allActionPending: true,
},
};
case RUN_ALL_RETRY_TASKS_SUCCESS:
case ARCHIVE_ALL_RETRY_TASKS_SUCCESS:
case DELETE_ALL_RETRY_TASKS_SUCCESS:
return {
...state,
retryTasks: {
...state.retryTasks,
allActionPending: false,
data: [],
},
};
case RUN_ALL_RETRY_TASKS_ERROR:
case ARCHIVE_ALL_RETRY_TASKS_ERROR:
case DELETE_ALL_RETRY_TASKS_ERROR:
return {
...state,
retryTasks: {
...state.retryTasks,
allActionPending: false,
},
};
case BATCH_RUN_RETRY_TASKS_BEGIN:
case BATCH_ARCHIVE_RETRY_TASKS_BEGIN:
case BATCH_DELETE_RETRY_TASKS_BEGIN:
return {
...state,
retryTasks: {
...state.retryTasks,
batchActionPending: true,
data: state.retryTasks.data.map((task) => {
if (!action.taskKeys.includes(task.key)) {
return task;
}
return {
...task,
requestPending: true,
};
}),
},
};
case BATCH_RUN_RETRY_TASKS_SUCCESS: {
const newData = state.retryTasks.data.filter(
(task) => !action.payload.pending_keys.includes(task.key)
);
return {
...state,
retryTasks: {
...state.retryTasks,
batchActionPending: false,
data: newData,
},
};
}
case BATCH_ARCHIVE_RETRY_TASKS_SUCCESS: {
const newData = state.retryTasks.data.filter(
(task) => !action.payload.archived_keys.includes(task.key)
);
return {
...state,
retryTasks: {
...state.retryTasks,
batchActionPending: false,
data: newData,
},
};
}
case BATCH_DELETE_RETRY_TASKS_SUCCESS: {
const newData = state.retryTasks.data.filter(
(task) => !action.payload.deleted_keys.includes(task.key)
);
return {
...state,
retryTasks: {
...state.retryTasks,
batchActionPending: false,
data: newData,
},
};
}
case BATCH_RUN_RETRY_TASKS_ERROR:
case BATCH_ARCHIVE_RETRY_TASKS_ERROR:
case BATCH_DELETE_RETRY_TASKS_ERROR:
return {
...state,
retryTasks: {
...state.retryTasks,
batchActionPending: false,
data: state.retryTasks.data.map((task) => {
if (!action.taskKeys.includes(task.key)) {
return task;
}
return {
...task,
requestPending: false,
};
}),
},
};
case RUN_ARCHIVED_TASK_BEGIN:
case DELETE_ARCHIVED_TASK_BEGIN:
return {
...state,
archivedTasks: {
...state.archivedTasks,
data: state.archivedTasks.data.map((task) => {
if (task.key !== action.taskKey) {
return task;
}
return { ...task, requestPending: true };
}),
},
};
case RUN_ARCHIVED_TASK_SUCCESS:
case DELETE_ARCHIVED_TASK_SUCCESS:
return {
...state,
archivedTasks: {
...state.archivedTasks,
data: state.archivedTasks.data.filter(
(task) => task.key !== action.taskKey
),
},
};
case RUN_ARCHIVED_TASK_ERROR:
case DELETE_ARCHIVED_TASK_ERROR:
return {
...state,
archivedTasks: {
...state.archivedTasks,
data: state.archivedTasks.data.map((task) => {
if (task.key !== action.taskKey) {
return task;
}
return { ...task, requestPending: false };
}),
},
};
case RUN_ALL_ARCHIVED_TASKS_BEGIN:
case DELETE_ALL_ARCHIVED_TASKS_BEGIN:
return {
...state,
archivedTasks: {
...state.archivedTasks,
allActionPending: true,
},
};
case RUN_ALL_ARCHIVED_TASKS_SUCCESS:
case DELETE_ALL_ARCHIVED_TASKS_SUCCESS:
return {
...state,
archivedTasks: {
...state.archivedTasks,
allActionPending: false,
data: [],
},
};
case RUN_ALL_ARCHIVED_TASKS_ERROR:
case DELETE_ALL_ARCHIVED_TASKS_ERROR:
return {
...state,
archivedTasks: {
...state.archivedTasks,
allActionPending: false,
},
};
case BATCH_RUN_ARCHIVED_TASKS_BEGIN:
case BATCH_DELETE_ARCHIVED_TASKS_BEGIN:
return {
...state,
archivedTasks: {
...state.archivedTasks,
batchActionPending: true,
data: state.archivedTasks.data.map((task) => {
2020-12-16 23:04:22 +08:00
if (!action.taskKeys.includes(task.key)) {
return task;
}
return {
...task,
requestPending: true,
};
}),
},
};
case BATCH_RUN_ARCHIVED_TASKS_SUCCESS: {
const newData = state.archivedTasks.data.filter(
2020-12-15 22:46:23 +08:00
(task) => !action.payload.pending_keys.includes(task.key)
);
return {
...state,
archivedTasks: {
...state.archivedTasks,
2020-12-15 22:46:23 +08:00
batchActionPending: false,
data: newData,
},
};
}
case BATCH_DELETE_ARCHIVED_TASKS_SUCCESS: {
const newData = state.archivedTasks.data.filter(
(task) => !action.payload.deleted_keys.includes(task.key)
);
return {
...state,
archivedTasks: {
...state.archivedTasks,
batchActionPending: false,
data: newData,
},
};
}
case BATCH_RUN_ARCHIVED_TASKS_ERROR:
case BATCH_DELETE_ARCHIVED_TASKS_ERROR:
return {
...state,
archivedTasks: {
...state.archivedTasks,
batchActionPending: false,
data: state.archivedTasks.data.map((task) => {
2020-12-16 23:04:22 +08:00
if (!action.taskKeys.includes(task.key)) {
return task;
}
return {
...task,
requestPending: false,
};
}),
},
};
2020-11-24 22:54:00 +08:00
default:
return state;
}
}
export default tasksReducer;