bigbuffet-rw/app/soapbox/actions/group_editor.js

114 lines
3.1 KiB
JavaScript
Raw Normal View History

2020-03-27 13:59:38 -07:00
import api from '../api';
2021-03-24 09:44:51 -07:00
import { isLoggedIn } from 'soapbox/utils/accounts';
2020-03-27 13:59:38 -07:00
export const GROUP_CREATE_REQUEST = 'GROUP_CREATE_REQUEST';
export const GROUP_CREATE_SUCCESS = 'GROUP_CREATE_SUCCESS';
export const GROUP_CREATE_FAIL = 'GROUP_CREATE_FAIL';
export const GROUP_UPDATE_REQUEST = 'GROUP_UPDATE_REQUEST';
export const GROUP_UPDATE_SUCCESS = 'GROUP_UPDATE_SUCCESS';
export const GROUP_UPDATE_FAIL = 'GROUP_UPDATE_FAIL';
export const GROUP_EDITOR_VALUE_CHANGE = 'GROUP_EDITOR_VALUE_CHANGE';
export const GROUP_EDITOR_RESET = 'GROUP_EDITOR_RESET';
export const GROUP_EDITOR_SETUP = 'GROUP_EDITOR_SETUP';
export const submit = (routerHistory) => (dispatch, getState) => {
2020-04-14 11:44:40 -07:00
const groupId = getState().getIn(['group_editor', 'groupId']);
const title = getState().getIn(['group_editor', 'title']);
const description = getState().getIn(['group_editor', 'description']);
const coverImage = getState().getIn(['group_editor', 'coverImage']);
if (groupId === null) {
dispatch(create(title, description, coverImage, routerHistory));
} else {
dispatch(update(groupId, title, description, coverImage, routerHistory));
}
2020-03-27 13:59:38 -07:00
};
export const create = (title, description, coverImage, routerHistory) => (dispatch, getState) => {
2021-03-24 09:44:51 -07:00
if (!isLoggedIn(getState)) return;
2020-03-27 13:59:38 -07:00
2020-04-14 11:44:40 -07:00
dispatch(createRequest());
2020-03-27 13:59:38 -07:00
2020-04-14 11:44:40 -07:00
const formData = new FormData();
formData.append('title', title);
formData.append('description', description);
2020-03-27 13:59:38 -07:00
2020-04-14 11:44:40 -07:00
if (coverImage !== null) {
formData.append('cover_image', coverImage);
}
2020-04-14 11:44:40 -07:00
api(getState).post('/api/v1/groups', formData, { headers: { 'Content-Type': 'multipart/form-data' } }).then(({ data }) => {
dispatch(createSuccess(data));
routerHistory.push(`/groups/${data.id}`);
}).catch(err => dispatch(createFail(err)));
};
2020-03-27 13:59:38 -07:00
export const createRequest = id => ({
2020-04-14 11:44:40 -07:00
type: GROUP_CREATE_REQUEST,
id,
2020-03-27 13:59:38 -07:00
});
export const createSuccess = group => ({
2020-04-14 11:44:40 -07:00
type: GROUP_CREATE_SUCCESS,
group,
2020-03-27 13:59:38 -07:00
});
export const createFail = error => ({
2020-04-14 11:44:40 -07:00
type: GROUP_CREATE_FAIL,
error,
2020-03-27 13:59:38 -07:00
});
export const update = (groupId, title, description, coverImage, routerHistory) => (dispatch, getState) => {
2021-03-24 09:44:51 -07:00
if (!isLoggedIn(getState)) return;
2020-03-27 13:59:38 -07:00
2020-04-14 11:44:40 -07:00
dispatch(updateRequest());
2020-03-27 13:59:38 -07:00
2020-04-14 11:44:40 -07:00
const formData = new FormData();
formData.append('title', title);
formData.append('description', description);
2020-03-27 13:59:38 -07:00
2020-04-14 11:44:40 -07:00
if (coverImage !== null) {
formData.append('cover_image', coverImage);
}
2020-04-14 11:44:40 -07:00
api(getState).put(`/api/v1/groups/${groupId}`, formData, { headers: { 'Content-Type': 'multipart/form-data' } }).then(({ data }) => {
dispatch(updateSuccess(data));
routerHistory.push(`/groups/${data.id}`);
}).catch(err => dispatch(updateFail(err)));
};
2020-03-27 13:59:38 -07:00
export const updateRequest = id => ({
2020-04-14 11:44:40 -07:00
type: GROUP_UPDATE_REQUEST,
id,
2020-03-27 13:59:38 -07:00
});
export const updateSuccess = group => ({
2020-04-14 11:44:40 -07:00
type: GROUP_UPDATE_SUCCESS,
group,
2020-03-27 13:59:38 -07:00
});
export const updateFail = error => ({
2020-04-14 11:44:40 -07:00
type: GROUP_UPDATE_FAIL,
error,
2020-03-27 13:59:38 -07:00
});
export const changeValue = (field, value) => ({
2020-04-14 11:44:40 -07:00
type: GROUP_EDITOR_VALUE_CHANGE,
field,
value,
2020-03-27 13:59:38 -07:00
});
export const reset = () => ({
2020-04-14 11:44:40 -07:00
type: GROUP_EDITOR_RESET,
2020-03-27 13:59:38 -07:00
});
export const setUp = (group) => ({
2020-04-14 11:44:40 -07:00
type: GROUP_EDITOR_SETUP,
group,
});