openreplay/frontend/app/duck/assignments.js
2023-01-02 17:59:16 +01:00

116 lines
4 KiB
JavaScript

import { List, Map, Set } from 'immutable';
import Assignment from 'Types/session/assignment';
import Activity from 'Types/session/activity';
import withRequestState, { RequestTypes } from './requestStateCreator';
import { createListUpdater } from './funcTools/tools';
import { editType, initType } from './funcTools/crud/types';
import { createInit, createEdit } from './funcTools/crud';
const idKey = 'id';
const name = 'assignment';
const listUpdater = createListUpdater(idKey);
const FETCH_PROJECTS = new RequestTypes('asignment/FETCH_PROJECTS');
const FETCH_META = new RequestTypes('asignment/FETCH_META');
const FETCH_ASSIGNMENTS = new RequestTypes('asignment/FETCH_ASSIGNMENTS');
const FETCH_ASSIGNMENT = new RequestTypes('asignment/FETCH_ASSIGNMENT');
const ADD_ACTIVITY = new RequestTypes('asignment/ADD_ACTIVITY');
const ADD_MESSAGE = new RequestTypes('asignment/ADD_MESSAGE');
const EDIT = editType(name);
const INIT = initType(name);
const initialState = Map({
list: List(),
instance: new Assignment(),
activeIssue: new Assignment(),
issueTypes: List(),
issueTypeIcons: Set(),
users: List(),
projects: List(),
projectsFetched: false
});
const reducer = (state = initialState, action = {}) => {
const users = state.get('users');
let issueTypes = []
switch (action.type) {
case INIT:
action.instance.issueType = issueTypes.length > 0 ? issueTypes[0].id : '';
return state.set('instance', new Assignment(action.instance));
case EDIT:
const inst = state.get('instance')
return state.set('instance', new Assignment({ ...inst, ...action.instance }));
case FETCH_PROJECTS.SUCCESS:
return state.set('projects', List(action.data)).set('projectsFetched', true);
case FETCH_ASSIGNMENTS.SUCCESS:
return state.set('list', List(action.data).map(as => new Assignment(as)));
case FETCH_ASSIGNMENT.SUCCESS:
return state.set('activeIssue', new Assignment({ ...action.data, users}));
case FETCH_META.SUCCESS:
issueTypes = action.data.issueTypes
const issueTypeIcons = {}
issueTypes.forEach(iss => {
issueTypeIcons[iss.id] = iss.iconUrl
})
return state.set('issueTypes', issueTypes)
.set('users', List(action.data.users))
.set('issueTypeIcons', issueTypeIcons)
case ADD_ACTIVITY.SUCCESS:
const instance = new Assignment(action.data);
return listUpdater(state, instance);
case ADD_MESSAGE.SUCCESS:
const user = users.filter(user => user.id === action.data.author).first();
const activity = new Activity({ type: 'message', user, ...action.data,});
return state.update([ 'activeIssue' ], issue => issue.activities.push(activity));
default:
return state;
}
};
export default withRequestState({
fetchProjects: FETCH_PROJECTS,
fetchMeta: FETCH_META,
fetchAssignments: FETCH_ASSIGNMENTS,
addActivity: ADD_ACTIVITY,
fetchAssignment: FETCH_ASSIGNMENT,
addMessage: ADD_MESSAGE
}, reducer);
export const init = createInit(name);
export const edit = createEdit(name);
export function fetchProjects() {
return {
types: FETCH_PROJECTS.toArray(),
call: client => client.get(`/integrations/issues/list_projects`)
};
}
export function fetchMeta(projectId) {
return {
types: FETCH_META.toArray(),
call: client => client.get(`/integrations/issues/${projectId}`)
}
}
export function fetchAssignments(sessionId) {
return {
types: FETCH_ASSIGNMENTS.toArray(),
call: client => client.get(`/sessions/${ sessionId }/assign`)
}
}
export function addActivity(sessionId, params) {
const data = { ...params, assignee: params.assignee, issueType: params.issueType }
return {
types: ADD_ACTIVITY.toArray(),
call: client => client.post(`/sessions/${ sessionId }/assign/projects/${params.projectId}`, data),
}
}
export function addMessage(sessionId, assignmentId, params) {
return {
types: ADD_MESSAGE.toArray(),
call: client => client.post(`/sessions/${ sessionId }/assign/${ assignmentId }/comment`, params),
}
}