2022-08-30 13:26:42 -07:00
|
|
|
import { defineMessages, IntlShape } from 'react-intl';
|
|
|
|
|
2022-09-08 14:25:02 -07:00
|
|
|
import api, { getLinks } from 'soapbox/api';
|
2022-08-30 13:26:42 -07:00
|
|
|
import { formatBytes } from 'soapbox/utils/media';
|
2022-11-26 11:25:48 -08:00
|
|
|
import resizeImage from 'soapbox/utils/resize-image';
|
2022-08-30 13:26:42 -07:00
|
|
|
|
2022-11-26 13:15:58 -08:00
|
|
|
import { importFetchedAccounts, importFetchedStatus, importFetchedStatuses } from './importer';
|
2022-08-30 13:26:42 -07:00
|
|
|
import { fetchMedia, uploadMedia } from './media';
|
2022-09-25 14:18:11 -07:00
|
|
|
import { closeModal, openModal } from './modals';
|
2022-08-30 13:26:42 -07:00
|
|
|
import snackbar from './snackbar';
|
2022-09-25 14:18:11 -07:00
|
|
|
import {
|
|
|
|
STATUS_FETCH_SOURCE_FAIL,
|
|
|
|
STATUS_FETCH_SOURCE_REQUEST,
|
|
|
|
STATUS_FETCH_SOURCE_SUCCESS,
|
|
|
|
} from './statuses';
|
2022-08-30 13:26:42 -07:00
|
|
|
|
|
|
|
import type { AxiosError } from 'axios';
|
|
|
|
import type { AppDispatch, RootState } from 'soapbox/store';
|
2022-09-21 14:27:53 -07:00
|
|
|
import type { APIEntity, Status as StatusEntity } from 'soapbox/types/entities';
|
2022-08-30 13:26:42 -07:00
|
|
|
|
|
|
|
const LOCATION_SEARCH_REQUEST = 'LOCATION_SEARCH_REQUEST';
|
|
|
|
const LOCATION_SEARCH_SUCCESS = 'LOCATION_SEARCH_SUCCESS';
|
|
|
|
const LOCATION_SEARCH_FAIL = 'LOCATION_SEARCH_FAIL';
|
|
|
|
|
2022-09-25 14:18:11 -07:00
|
|
|
const EDIT_EVENT_NAME_CHANGE = 'EDIT_EVENT_NAME_CHANGE';
|
|
|
|
const EDIT_EVENT_DESCRIPTION_CHANGE = 'EDIT_EVENT_DESCRIPTION_CHANGE';
|
|
|
|
const EDIT_EVENT_START_TIME_CHANGE = 'EDIT_EVENT_START_TIME_CHANGE';
|
|
|
|
const EDIT_EVENT_HAS_END_TIME_CHANGE = 'EDIT_EVENT_HAS_END_TIME_CHANGE';
|
|
|
|
const EDIT_EVENT_END_TIME_CHANGE = 'EDIT_EVENT_END_TIME_CHANGE';
|
|
|
|
const EDIT_EVENT_APPROVAL_REQUIRED_CHANGE = 'EDIT_EVENT_APPROVAL_REQUIRED_CHANGE';
|
|
|
|
const EDIT_EVENT_LOCATION_CHANGE = 'EDIT_EVENT_LOCATION_CHANGE';
|
2022-08-30 13:26:42 -07:00
|
|
|
|
|
|
|
const EVENT_BANNER_UPLOAD_REQUEST = 'EVENT_BANNER_UPLOAD_REQUEST';
|
|
|
|
const EVENT_BANNER_UPLOAD_PROGRESS = 'EVENT_BANNER_UPLOAD_PROGRESS';
|
|
|
|
const EVENT_BANNER_UPLOAD_SUCCESS = 'EVENT_BANNER_UPLOAD_SUCCESS';
|
|
|
|
const EVENT_BANNER_UPLOAD_FAIL = 'EVENT_BANNER_UPLOAD_FAIL';
|
|
|
|
const EVENT_BANNER_UPLOAD_UNDO = 'EVENT_BANNER_UPLOAD_UNDO';
|
|
|
|
|
|
|
|
const EVENT_SUBMIT_REQUEST = 'EVENT_SUBMIT_REQUEST';
|
|
|
|
const EVENT_SUBMIT_SUCCESS = 'EVENT_SUBMIT_SUCCESS';
|
|
|
|
const EVENT_SUBMIT_FAIL = 'EVENT_SUBMIT_FAIL';
|
|
|
|
|
2022-09-07 11:03:26 -07:00
|
|
|
const EVENT_JOIN_REQUEST = 'EVENT_JOIN_REQUEST';
|
|
|
|
const EVENT_JOIN_SUCCESS = 'EVENT_JOIN_SUCCESS';
|
|
|
|
const EVENT_JOIN_FAIL = 'EVENT_JOIN_FAIL';
|
|
|
|
|
|
|
|
const EVENT_LEAVE_REQUEST = 'EVENT_LEAVE_REQUEST';
|
|
|
|
const EVENT_LEAVE_SUCCESS = 'EVENT_LEAVE_SUCCESS';
|
|
|
|
const EVENT_LEAVE_FAIL = 'EVENT_LEAVE_FAIL';
|
|
|
|
|
2022-09-08 14:25:02 -07:00
|
|
|
const EVENT_PARTICIPATIONS_FETCH_REQUEST = 'EVENT_PARTICIPATIONS_FETCH_REQUEST';
|
|
|
|
const EVENT_PARTICIPATIONS_FETCH_SUCCESS = 'EVENT_PARTICIPATIONS_FETCH_SUCCESS';
|
|
|
|
const EVENT_PARTICIPATIONS_FETCH_FAIL = 'EVENT_PARTICIPATIONS_FETCH_FAIL';
|
|
|
|
|
|
|
|
const EVENT_PARTICIPATIONS_EXPAND_REQUEST = 'EVENT_PARTICIPATIONS_EXPAND_REQUEST';
|
|
|
|
const EVENT_PARTICIPATIONS_EXPAND_SUCCESS = 'EVENT_PARTICIPATIONS_EXPAND_SUCCESS';
|
|
|
|
const EVENT_PARTICIPATIONS_EXPAND_FAIL = 'EVENT_PARTICIPATIONS_EXPAND_FAIL';
|
|
|
|
|
|
|
|
const EVENT_PARTICIPATION_REQUESTS_FETCH_REQUEST = 'EVENT_PARTICIPATION_REQUESTS_FETCH_REQUEST';
|
|
|
|
const EVENT_PARTICIPATION_REQUESTS_FETCH_SUCCESS = 'EVENT_PARTICIPATION_REQUESTS_FETCH_SUCCESS';
|
|
|
|
const EVENT_PARTICIPATION_REQUESTS_FETCH_FAIL = 'EVENT_PARTICIPATION_REQUESTS_FETCH_FAIL';
|
|
|
|
|
|
|
|
const EVENT_PARTICIPATION_REQUESTS_EXPAND_REQUEST = 'EVENT_PARTICIPATION_REQUESTS_EXPAND_REQUEST';
|
|
|
|
const EVENT_PARTICIPATION_REQUESTS_EXPAND_SUCCESS = 'EVENT_PARTICIPATION_REQUESTS_EXPAND_SUCCESS';
|
|
|
|
const EVENT_PARTICIPATION_REQUESTS_EXPAND_FAIL = 'EVENT_PARTICIPATION_REQUESTS_EXPAND_FAIL';
|
|
|
|
|
2022-09-25 14:18:11 -07:00
|
|
|
const EVENT_PARTICIPATION_REQUEST_AUTHORIZE_REQUEST = 'EVENT_PARTICIPATION_REQUEST_AUTHORIZE_REQUEST';
|
|
|
|
const EVENT_PARTICIPATION_REQUEST_AUTHORIZE_SUCCESS = 'EVENT_PARTICIPATION_REQUEST_AUTHORIZE_SUCCESS';
|
|
|
|
const EVENT_PARTICIPATION_REQUEST_AUTHORIZE_FAIL = 'EVENT_PARTICIPATION_REQUEST_AUTHORIZE_FAIL';
|
|
|
|
|
|
|
|
const EVENT_PARTICIPATION_REQUEST_REJECT_REQUEST = 'EVENT_PARTICIPATION_REQUEST_REJECT_REQUEST';
|
|
|
|
const EVENT_PARTICIPATION_REQUEST_REJECT_SUCCESS = 'EVENT_PARTICIPATION_REQUEST_REJECT_SUCCESS';
|
|
|
|
const EVENT_PARTICIPATION_REQUEST_REJECT_FAIL = 'EVENT_PARTICIPATION_REQUEST_REJECT_FAIL';
|
|
|
|
|
|
|
|
const EVENT_COMPOSE_CANCEL = 'EVENT_COMPOSE_CANCEL';
|
|
|
|
|
|
|
|
const EVENT_FORM_SET = 'EVENT_FORM_SET';
|
|
|
|
|
2022-11-26 13:15:58 -08:00
|
|
|
const RECENT_EVENTS_FETCH_REQUEST = 'RECENT_EVENTS_FETCH_REQUEST';
|
|
|
|
const RECENT_EVENTS_FETCH_SUCCESS = 'RECENT_EVENTS_FETCH_SUCCESS';
|
|
|
|
const RECENT_EVENTS_FETCH_FAIL = 'RECENT_EVENTS_FETCH_FAIL';
|
|
|
|
const JOINED_EVENTS_FETCH_REQUEST = 'JOINED_EVENTS_FETCH_REQUEST';
|
|
|
|
const JOINED_EVENTS_FETCH_SUCCESS = 'JOINED_EVENTS_FETCH_SUCCESS';
|
|
|
|
const JOINED_EVENTS_FETCH_FAIL = 'JOINED_EVENTS_FETCH_FAIL';
|
|
|
|
|
2022-09-08 14:25:02 -07:00
|
|
|
const noOp = () => new Promise(f => f(undefined));
|
|
|
|
|
2022-08-30 13:26:42 -07:00
|
|
|
const messages = defineMessages({
|
|
|
|
exceededImageSizeLimit: { id: 'upload_error.image_size_limit', defaultMessage: 'Image exceeds the current file size limit ({limit})' },
|
2022-09-25 14:18:11 -07:00
|
|
|
success: { id: 'compose_event.submit_success', defaultMessage: 'Your event was created' },
|
2022-09-30 14:20:58 -07:00
|
|
|
editSuccess: { id: 'compose_event.edit_success', defaultMessage: 'Your event was edited' },
|
2022-09-07 11:03:26 -07:00
|
|
|
joinSuccess: { id: 'join_event.success', defaultMessage: 'Joined the event' },
|
|
|
|
joinRequestSuccess: { id: 'join_event.request_success', defaultMessage: 'Requested to join the event' },
|
2022-08-30 13:26:42 -07:00
|
|
|
view: { id: 'snackbar.view', defaultMessage: 'View' },
|
2022-09-25 14:18:11 -07:00
|
|
|
authorized: { id: 'compose_event.participation_requests.authorize_success', defaultMessage: 'User accepted' },
|
|
|
|
rejected: { id: 'compose_event.participation_requests.reject_success', defaultMessage: 'User rejected' },
|
2022-08-30 13:26:42 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
const locationSearch = (query: string, signal?: AbortSignal) =>
|
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
dispatch({ type: LOCATION_SEARCH_REQUEST, query });
|
|
|
|
return api(getState).get('/api/v1/pleroma/search/location', { params: { q: query }, signal }).then(({ data: locations }) => {
|
|
|
|
dispatch({ type: LOCATION_SEARCH_SUCCESS, locations });
|
|
|
|
return locations;
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch({ type: LOCATION_SEARCH_FAIL });
|
|
|
|
throw error;
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2022-09-25 14:18:11 -07:00
|
|
|
const changeEditEventName = (value: string) => ({
|
|
|
|
type: EDIT_EVENT_NAME_CHANGE,
|
2022-08-30 13:26:42 -07:00
|
|
|
value,
|
|
|
|
});
|
|
|
|
|
2022-09-25 14:18:11 -07:00
|
|
|
const changeEditEventDescription = (value: string) => ({
|
|
|
|
type: EDIT_EVENT_DESCRIPTION_CHANGE,
|
2022-08-30 13:26:42 -07:00
|
|
|
value,
|
|
|
|
});
|
|
|
|
|
2022-09-25 14:18:11 -07:00
|
|
|
const changeEditEventStartTime = (value: Date) => ({
|
|
|
|
type: EDIT_EVENT_START_TIME_CHANGE,
|
2022-08-30 13:26:42 -07:00
|
|
|
value,
|
|
|
|
});
|
|
|
|
|
2022-09-25 14:18:11 -07:00
|
|
|
const changeEditEventEndTime = (value: Date) => ({
|
|
|
|
type: EDIT_EVENT_END_TIME_CHANGE,
|
2022-08-30 13:26:42 -07:00
|
|
|
value,
|
|
|
|
});
|
|
|
|
|
2022-09-25 14:18:11 -07:00
|
|
|
const changeEditEventHasEndTime = (value: boolean) => ({
|
|
|
|
type: EDIT_EVENT_HAS_END_TIME_CHANGE,
|
2022-08-30 13:26:42 -07:00
|
|
|
value,
|
|
|
|
});
|
|
|
|
|
2022-09-25 14:18:11 -07:00
|
|
|
const changeEditEventApprovalRequired = (value: boolean) => ({
|
|
|
|
type: EDIT_EVENT_APPROVAL_REQUIRED_CHANGE,
|
2022-08-30 13:26:42 -07:00
|
|
|
value,
|
|
|
|
});
|
|
|
|
|
2022-09-25 14:18:11 -07:00
|
|
|
const changeEditEventLocation = (value: string | null) =>
|
2022-08-30 13:26:42 -07:00
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
let location = null;
|
|
|
|
|
|
|
|
if (value) {
|
|
|
|
location = getState().locations.get(value);
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch({
|
2022-09-25 14:18:11 -07:00
|
|
|
type: EDIT_EVENT_LOCATION_CHANGE,
|
2022-08-30 13:26:42 -07:00
|
|
|
value: location,
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
const uploadEventBanner = (file: File, intl: IntlShape) =>
|
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
const maxImageSize = getState().instance.configuration.getIn(['media_attachments', 'image_size_limit']) as number | undefined;
|
|
|
|
|
|
|
|
let progress = 0;
|
|
|
|
|
|
|
|
dispatch(uploadEventBannerRequest());
|
|
|
|
|
|
|
|
if (maxImageSize && (file.size > maxImageSize)) {
|
|
|
|
const limit = formatBytes(maxImageSize);
|
|
|
|
const message = intl.formatMessage(messages.exceededImageSizeLimit, { limit });
|
|
|
|
dispatch(snackbar.error(message));
|
|
|
|
dispatch(uploadEventBannerFail(true));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
resizeImage(file).then(file => {
|
|
|
|
const data = new FormData();
|
|
|
|
data.append('file', file);
|
|
|
|
// Account for disparity in size of original image and resized data
|
|
|
|
|
|
|
|
const onUploadProgress = ({ loaded }: any) => {
|
|
|
|
progress = loaded;
|
|
|
|
dispatch(uploadEventBannerProgress(progress));
|
|
|
|
};
|
|
|
|
|
|
|
|
return dispatch(uploadMedia(data, onUploadProgress))
|
|
|
|
.then(({ status, data }) => {
|
|
|
|
// If server-side processing of the media attachment has not completed yet,
|
|
|
|
// poll the server until it is, before showing the media attachment as uploaded
|
|
|
|
if (status === 200) {
|
|
|
|
dispatch(uploadEventBannerSuccess(data, file));
|
|
|
|
} else if (status === 202) {
|
|
|
|
const poll = () => {
|
|
|
|
dispatch(fetchMedia(data.id)).then(({ status, data }) => {
|
|
|
|
if (status === 200) {
|
|
|
|
dispatch(uploadEventBannerSuccess(data, file));
|
|
|
|
} else if (status === 206) {
|
|
|
|
setTimeout(() => poll(), 1000);
|
|
|
|
}
|
|
|
|
}).catch(error => dispatch(uploadEventBannerFail(error)));
|
|
|
|
};
|
|
|
|
|
|
|
|
poll();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}).catch(error => dispatch(uploadEventBannerFail(error)));
|
|
|
|
};
|
|
|
|
|
|
|
|
const uploadEventBannerRequest = () => ({
|
|
|
|
type: EVENT_BANNER_UPLOAD_REQUEST,
|
|
|
|
});
|
|
|
|
|
|
|
|
const uploadEventBannerProgress = (loaded: number) => ({
|
|
|
|
type: EVENT_BANNER_UPLOAD_PROGRESS,
|
2022-09-07 12:24:10 -07:00
|
|
|
loaded,
|
2022-08-30 13:26:42 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
const uploadEventBannerSuccess = (media: APIEntity, file: File) => ({
|
|
|
|
type: EVENT_BANNER_UPLOAD_SUCCESS,
|
2022-09-07 12:24:10 -07:00
|
|
|
media,
|
2022-08-30 13:26:42 -07:00
|
|
|
file,
|
|
|
|
});
|
|
|
|
|
|
|
|
const uploadEventBannerFail = (error: AxiosError | true) => ({
|
|
|
|
type: EVENT_BANNER_UPLOAD_FAIL,
|
2022-09-07 12:24:10 -07:00
|
|
|
error,
|
2022-08-30 13:26:42 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
const undoUploadEventBanner = () => ({
|
|
|
|
type: EVENT_BANNER_UPLOAD_UNDO,
|
|
|
|
});
|
|
|
|
|
|
|
|
const submitEvent = () =>
|
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
const state = getState();
|
|
|
|
|
2022-09-28 13:22:45 -07:00
|
|
|
const id = state.compose_event.id;
|
2022-09-25 14:18:11 -07:00
|
|
|
const name = state.compose_event.name;
|
|
|
|
const status = state.compose_event.status;
|
|
|
|
const banner = state.compose_event.banner;
|
|
|
|
const startTime = state.compose_event.start_time;
|
|
|
|
const endTime = state.compose_event.end_time;
|
|
|
|
const joinMode = state.compose_event.approval_required ? 'restricted' : 'free';
|
|
|
|
const location = state.compose_event.location;
|
2022-08-30 13:26:42 -07:00
|
|
|
|
2022-09-25 14:18:11 -07:00
|
|
|
if (!name || !name.length) {
|
2022-08-30 13:26:42 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(submitEventRequest());
|
|
|
|
|
|
|
|
const params: Record<string, any> = {
|
|
|
|
name,
|
|
|
|
status,
|
|
|
|
start_time: startTime,
|
|
|
|
join_mode: joinMode,
|
|
|
|
};
|
|
|
|
|
2022-09-08 14:25:02 -07:00
|
|
|
if (endTime) params.end_time = endTime;
|
|
|
|
if (banner) params.banner_id = banner.id;
|
2022-08-30 13:26:42 -07:00
|
|
|
if (location) params.location_id = location.origin_id;
|
|
|
|
|
2022-09-28 13:22:45 -07:00
|
|
|
return api(getState).request({
|
|
|
|
url: id === null ? '/api/v1/pleroma/events' : `/api/v1/pleroma/events/${id}`,
|
|
|
|
method: id === null ? 'post' : 'put',
|
|
|
|
data: params,
|
|
|
|
}).then(({ data }) => {
|
2022-09-25 14:18:11 -07:00
|
|
|
dispatch(closeModal('COMPOSE_EVENT'));
|
2022-09-07 11:03:26 -07:00
|
|
|
dispatch(importFetchedStatus(data));
|
2022-08-30 13:26:42 -07:00
|
|
|
dispatch(submitEventSuccess(data));
|
2022-09-30 14:20:58 -07:00
|
|
|
dispatch(snackbar.success(id ? messages.editSuccess : messages.success, messages.view, `/@${data.account.acct}/events/${data.id}`));
|
2022-08-30 13:26:42 -07:00
|
|
|
}).catch(function(error) {
|
|
|
|
dispatch(submitEventFail(error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
const submitEventRequest = () => ({
|
|
|
|
type: EVENT_SUBMIT_REQUEST,
|
|
|
|
});
|
|
|
|
|
|
|
|
const submitEventSuccess = (status: APIEntity) => ({
|
|
|
|
type: EVENT_SUBMIT_SUCCESS,
|
2022-09-07 12:24:10 -07:00
|
|
|
status,
|
2022-08-30 13:26:42 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
const submitEventFail = (error: AxiosError) => ({
|
|
|
|
type: EVENT_SUBMIT_FAIL,
|
2022-09-07 12:24:10 -07:00
|
|
|
error,
|
2022-08-30 13:26:42 -07:00
|
|
|
});
|
|
|
|
|
2022-09-07 11:03:26 -07:00
|
|
|
const joinEvent = (id: string, participationMessage?: string) =>
|
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
const status = getState().statuses.get(id);
|
|
|
|
|
2022-09-08 14:25:02 -07:00
|
|
|
if (!status || !status.event || status.event.join_state) {
|
|
|
|
return dispatch(noOp);
|
|
|
|
}
|
2022-09-07 11:03:26 -07:00
|
|
|
|
2022-09-21 14:27:53 -07:00
|
|
|
dispatch(joinEventRequest(status));
|
2022-09-07 11:03:26 -07:00
|
|
|
|
2022-09-25 14:18:11 -07:00
|
|
|
return api(getState).post(`/api/v1/pleroma/events/${id}/join`, {
|
|
|
|
participation_message: participationMessage,
|
|
|
|
}).then(({ data }) => {
|
2022-09-07 11:03:26 -07:00
|
|
|
dispatch(importFetchedStatus(data));
|
|
|
|
dispatch(joinEventSuccess(data));
|
|
|
|
dispatch(snackbar.success(
|
|
|
|
data.pleroma.event?.join_state === 'pending' ? messages.joinRequestSuccess : messages.joinSuccess,
|
|
|
|
messages.view,
|
|
|
|
`/@${data.account.acct}/events/${data.id}`,
|
|
|
|
));
|
|
|
|
}).catch(function(error) {
|
2022-09-21 14:27:53 -07:00
|
|
|
dispatch(joinEventFail(error, status, status?.event?.join_state || null));
|
2022-09-07 11:03:26 -07:00
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2022-09-21 14:27:53 -07:00
|
|
|
const joinEventRequest = (status: StatusEntity) => ({
|
2022-09-07 11:03:26 -07:00
|
|
|
type: EVENT_JOIN_REQUEST,
|
2022-09-21 14:27:53 -07:00
|
|
|
id: status.id,
|
2022-09-07 11:03:26 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
const joinEventSuccess = (status: APIEntity) => ({
|
|
|
|
type: EVENT_JOIN_SUCCESS,
|
2022-09-21 14:27:53 -07:00
|
|
|
id: status.id,
|
2022-09-07 11:03:26 -07:00
|
|
|
});
|
|
|
|
|
2022-09-21 14:27:53 -07:00
|
|
|
const joinEventFail = (error: AxiosError, status: StatusEntity, previousState: string | null) => ({
|
2022-09-07 11:03:26 -07:00
|
|
|
type: EVENT_JOIN_FAIL,
|
2022-09-07 12:24:10 -07:00
|
|
|
error,
|
2022-09-21 14:27:53 -07:00
|
|
|
id: status.id,
|
2022-09-07 12:24:10 -07:00
|
|
|
previousState,
|
2022-09-07 11:03:26 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
const leaveEvent = (id: string) =>
|
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
const status = getState().statuses.get(id);
|
|
|
|
|
2022-09-08 14:25:02 -07:00
|
|
|
if (!status || !status.event || !status.event.join_state) {
|
|
|
|
return dispatch(noOp);
|
|
|
|
}
|
2022-09-07 11:03:26 -07:00
|
|
|
|
2022-09-21 14:27:53 -07:00
|
|
|
dispatch(leaveEventRequest(status));
|
2022-09-07 11:03:26 -07:00
|
|
|
|
|
|
|
return api(getState).post(`/api/v1/pleroma/events/${id}/leave`).then(({ data }) => {
|
|
|
|
dispatch(importFetchedStatus(data));
|
|
|
|
dispatch(leaveEventSuccess(data));
|
|
|
|
}).catch(function(error) {
|
2022-09-21 14:27:53 -07:00
|
|
|
dispatch(leaveEventFail(error, status));
|
2022-09-07 11:03:26 -07:00
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2022-09-21 14:27:53 -07:00
|
|
|
const leaveEventRequest = (status: StatusEntity) => ({
|
2022-09-07 11:03:26 -07:00
|
|
|
type: EVENT_LEAVE_REQUEST,
|
2022-09-21 14:27:53 -07:00
|
|
|
id: status.id,
|
2022-09-07 11:03:26 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
const leaveEventSuccess = (status: APIEntity) => ({
|
|
|
|
type: EVENT_LEAVE_SUCCESS,
|
2022-09-21 14:27:53 -07:00
|
|
|
id: status.id,
|
2022-09-07 11:03:26 -07:00
|
|
|
});
|
|
|
|
|
2022-09-21 14:27:53 -07:00
|
|
|
const leaveEventFail = (error: AxiosError, status: StatusEntity) => ({
|
2022-09-07 11:03:26 -07:00
|
|
|
type: EVENT_LEAVE_FAIL,
|
2022-09-21 14:27:53 -07:00
|
|
|
id: status.id,
|
2022-09-07 12:24:10 -07:00
|
|
|
error,
|
2022-09-07 11:03:26 -07:00
|
|
|
});
|
|
|
|
|
2022-09-08 14:25:02 -07:00
|
|
|
const fetchEventParticipations = (id: string) =>
|
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
dispatch(fetchEventParticipationsRequest(id));
|
|
|
|
|
|
|
|
return api(getState).get(`/api/v1/pleroma/events/${id}/participations`).then(response => {
|
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
|
|
|
dispatch(importFetchedAccounts(response.data));
|
|
|
|
return dispatch(fetchEventParticipationsSuccess(id, response.data, next ? next.uri : null));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch(fetchEventParticipationsFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
const fetchEventParticipationsRequest = (id: string) => ({
|
|
|
|
type: EVENT_PARTICIPATIONS_FETCH_REQUEST,
|
|
|
|
id,
|
|
|
|
});
|
|
|
|
|
|
|
|
const fetchEventParticipationsSuccess = (id: string, accounts: APIEntity[], next: string | null) => ({
|
|
|
|
type: EVENT_PARTICIPATIONS_FETCH_SUCCESS,
|
|
|
|
id,
|
|
|
|
accounts,
|
|
|
|
next,
|
|
|
|
});
|
|
|
|
|
|
|
|
const fetchEventParticipationsFail = (id: string, error: AxiosError) => ({
|
|
|
|
type: EVENT_PARTICIPATIONS_FETCH_FAIL,
|
|
|
|
id,
|
|
|
|
error,
|
|
|
|
});
|
|
|
|
|
|
|
|
const expandEventParticipations = (id: string) =>
|
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
const url = getState().user_lists.event_participations.get(id)?.next || null;
|
|
|
|
|
|
|
|
if (url === null) {
|
|
|
|
return dispatch(noOp);
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(expandEventParticipationsRequest(id));
|
|
|
|
|
|
|
|
return api(getState).get(url).then(response => {
|
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
|
|
|
dispatch(importFetchedAccounts(response.data));
|
|
|
|
return dispatch(expandEventParticipationsSuccess(id, response.data, next ? next.uri : null));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch(expandEventParticipationsFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
const expandEventParticipationsRequest = (id: string) => ({
|
|
|
|
type: EVENT_PARTICIPATIONS_EXPAND_REQUEST,
|
|
|
|
id,
|
|
|
|
});
|
|
|
|
|
|
|
|
const expandEventParticipationsSuccess = (id: string, accounts: APIEntity[], next: string | null) => ({
|
|
|
|
type: EVENT_PARTICIPATIONS_EXPAND_SUCCESS,
|
|
|
|
id,
|
|
|
|
accounts,
|
|
|
|
next,
|
|
|
|
});
|
|
|
|
|
|
|
|
const expandEventParticipationsFail = (id: string, error: AxiosError) => ({
|
|
|
|
type: EVENT_PARTICIPATIONS_EXPAND_FAIL,
|
|
|
|
id,
|
|
|
|
error,
|
|
|
|
});
|
|
|
|
|
|
|
|
const fetchEventParticipationRequests = (id: string) =>
|
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
dispatch(fetchEventParticipationRequestsRequest(id));
|
|
|
|
|
|
|
|
return api(getState).get(`/api/v1/pleroma/events/${id}/participation_requests`).then(response => {
|
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
|
|
|
dispatch(importFetchedAccounts(response.data.map(({ account }: APIEntity) => account)));
|
|
|
|
return dispatch(fetchEventParticipationRequestsSuccess(id, response.data, next ? next.uri : null));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch(fetchEventParticipationRequestsFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
const fetchEventParticipationRequestsRequest = (id: string) => ({
|
|
|
|
type: EVENT_PARTICIPATION_REQUESTS_FETCH_REQUEST,
|
|
|
|
id,
|
|
|
|
});
|
|
|
|
|
|
|
|
const fetchEventParticipationRequestsSuccess = (id: string, participations: APIEntity[], next: string | null) => ({
|
|
|
|
type: EVENT_PARTICIPATION_REQUESTS_FETCH_SUCCESS,
|
|
|
|
id,
|
|
|
|
participations,
|
|
|
|
next,
|
|
|
|
});
|
|
|
|
|
|
|
|
const fetchEventParticipationRequestsFail = (id: string, error: AxiosError) => ({
|
|
|
|
type: EVENT_PARTICIPATION_REQUESTS_FETCH_FAIL,
|
|
|
|
id,
|
|
|
|
error,
|
|
|
|
});
|
|
|
|
|
|
|
|
const expandEventParticipationRequests = (id: string) =>
|
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
const url = getState().user_lists.event_participations.get(id)?.next || null;
|
|
|
|
|
|
|
|
if (url === null) {
|
|
|
|
return dispatch(noOp);
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch(expandEventParticipationRequestsRequest(id));
|
|
|
|
|
|
|
|
return api(getState).get(url).then(response => {
|
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
|
|
|
dispatch(importFetchedAccounts(response.data.map(({ account }: APIEntity) => account)));
|
|
|
|
return dispatch(expandEventParticipationRequestsSuccess(id, response.data, next ? next.uri : null));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch(expandEventParticipationRequestsFail(id, error));
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
const expandEventParticipationRequestsRequest = (id: string) => ({
|
|
|
|
type: EVENT_PARTICIPATION_REQUESTS_EXPAND_REQUEST,
|
|
|
|
id,
|
|
|
|
});
|
|
|
|
|
|
|
|
const expandEventParticipationRequestsSuccess = (id: string, participations: APIEntity[], next: string | null) => ({
|
|
|
|
type: EVENT_PARTICIPATION_REQUESTS_EXPAND_SUCCESS,
|
|
|
|
id,
|
|
|
|
participations,
|
|
|
|
next,
|
|
|
|
});
|
|
|
|
|
|
|
|
const expandEventParticipationRequestsFail = (id: string, error: AxiosError) => ({
|
|
|
|
type: EVENT_PARTICIPATION_REQUESTS_EXPAND_FAIL,
|
|
|
|
id,
|
|
|
|
error,
|
|
|
|
});
|
|
|
|
|
2022-09-25 14:18:11 -07:00
|
|
|
const authorizeEventParticipationRequest = (id: string, accountId: string) =>
|
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
dispatch(authorizeEventParticipationRequestRequest(id, accountId));
|
|
|
|
|
|
|
|
return api(getState)
|
|
|
|
.post(`/api/v1/pleroma/events/${id}/participation_requests/${accountId}/authorize`)
|
|
|
|
.then(() => {
|
|
|
|
dispatch(authorizeEventParticipationRequestSuccess(id, accountId));
|
|
|
|
dispatch(snackbar.success(messages.authorized));
|
|
|
|
})
|
|
|
|
.catch(error => dispatch(authorizeEventParticipationRequestFail(id, accountId, error)));
|
|
|
|
};
|
|
|
|
|
|
|
|
const authorizeEventParticipationRequestRequest = (id: string, accountId: string) => ({
|
|
|
|
type: EVENT_PARTICIPATION_REQUEST_AUTHORIZE_REQUEST,
|
|
|
|
id,
|
|
|
|
accountId,
|
|
|
|
});
|
|
|
|
|
|
|
|
const authorizeEventParticipationRequestSuccess = (id: string, accountId: string) => ({
|
|
|
|
type: EVENT_PARTICIPATION_REQUEST_AUTHORIZE_SUCCESS,
|
|
|
|
id,
|
|
|
|
accountId,
|
|
|
|
});
|
|
|
|
|
|
|
|
const authorizeEventParticipationRequestFail = (id: string, accountId: string, error: AxiosError) => ({
|
|
|
|
type: EVENT_PARTICIPATION_REQUEST_AUTHORIZE_FAIL,
|
|
|
|
id,
|
|
|
|
accountId,
|
|
|
|
error,
|
|
|
|
});
|
|
|
|
|
|
|
|
const rejectEventParticipationRequest = (id: string, accountId: string) =>
|
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
dispatch(rejectEventParticipationRequestRequest(id, accountId));
|
|
|
|
|
|
|
|
return api(getState)
|
|
|
|
.post(`/api/v1/pleroma/events/${id}/participation_requests/${accountId}/reject`)
|
|
|
|
.then(() => {
|
|
|
|
dispatch(rejectEventParticipationRequestSuccess(id, accountId));
|
|
|
|
dispatch(snackbar.success(messages.rejected));
|
|
|
|
})
|
|
|
|
.catch(error => dispatch(rejectEventParticipationRequestFail(id, accountId, error)));
|
|
|
|
};
|
|
|
|
|
|
|
|
const rejectEventParticipationRequestRequest = (id: string, accountId: string) => ({
|
|
|
|
type: EVENT_PARTICIPATION_REQUEST_REJECT_REQUEST,
|
|
|
|
id,
|
|
|
|
accountId,
|
|
|
|
});
|
|
|
|
|
|
|
|
const rejectEventParticipationRequestSuccess = (id: string, accountId: string) => ({
|
|
|
|
type: EVENT_PARTICIPATION_REQUEST_REJECT_SUCCESS,
|
|
|
|
id,
|
|
|
|
accountId,
|
|
|
|
});
|
|
|
|
|
|
|
|
const rejectEventParticipationRequestFail = (id: string, accountId: string, error: AxiosError) => ({
|
|
|
|
type: EVENT_PARTICIPATION_REQUEST_REJECT_FAIL,
|
|
|
|
id,
|
|
|
|
accountId,
|
|
|
|
error,
|
|
|
|
});
|
|
|
|
|
2022-09-08 14:25:02 -07:00
|
|
|
const fetchEventIcs = (id: string) =>
|
|
|
|
(dispatch: any, getState: () => RootState) =>
|
|
|
|
api(getState).get(`/api/v1/pleroma/events/${id}/ics`);
|
|
|
|
|
2022-09-25 14:18:11 -07:00
|
|
|
const cancelEventCompose = () => ({
|
|
|
|
type: EVENT_COMPOSE_CANCEL,
|
|
|
|
});
|
|
|
|
|
|
|
|
const editEvent = (id: string) => (dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
const status = getState().statuses.get(id)!;
|
|
|
|
|
|
|
|
dispatch({ type: STATUS_FETCH_SOURCE_REQUEST });
|
|
|
|
|
|
|
|
api(getState).get(`/api/v1/statuses/${id}/source`).then(response => {
|
|
|
|
dispatch({ type: STATUS_FETCH_SOURCE_SUCCESS });
|
|
|
|
dispatch({
|
|
|
|
type: EVENT_FORM_SET,
|
|
|
|
status,
|
|
|
|
text: response.data.text,
|
|
|
|
location: response.data.location,
|
|
|
|
});
|
|
|
|
dispatch(openModal('COMPOSE_EVENT'));
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch({ type: STATUS_FETCH_SOURCE_FAIL, error });
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2022-11-26 13:15:58 -08:00
|
|
|
const fetchRecentEvents = () =>
|
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
if (getState().status_lists.get('recent_events')?.isLoading) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch({ type: RECENT_EVENTS_FETCH_REQUEST });
|
|
|
|
|
|
|
|
api(getState).get('/api/v1/timelines/public?only_events=true').then(response => {
|
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
|
|
|
dispatch(importFetchedStatuses(response.data));
|
|
|
|
dispatch({
|
|
|
|
type: RECENT_EVENTS_FETCH_SUCCESS,
|
|
|
|
statuses: response.data,
|
|
|
|
next: next ? next.uri : null,
|
|
|
|
});
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch({ type: RECENT_EVENTS_FETCH_FAIL, error });
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
const fetchJoinedEvents = () =>
|
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
if (getState().status_lists.get('joined_events')?.isLoading) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
dispatch({ type: JOINED_EVENTS_FETCH_REQUEST });
|
|
|
|
|
|
|
|
api(getState).get('/api/v1/pleroma/events/joined_events').then(response => {
|
|
|
|
const next = getLinks(response).refs.find(link => link.rel === 'next');
|
|
|
|
dispatch(importFetchedStatuses(response.data));
|
|
|
|
dispatch({
|
|
|
|
type: JOINED_EVENTS_FETCH_SUCCESS,
|
|
|
|
statuses: response.data,
|
|
|
|
next: next ? next.uri : null,
|
|
|
|
});
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch({ type: JOINED_EVENTS_FETCH_FAIL, error });
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2022-08-30 13:26:42 -07:00
|
|
|
export {
|
|
|
|
LOCATION_SEARCH_REQUEST,
|
|
|
|
LOCATION_SEARCH_SUCCESS,
|
|
|
|
LOCATION_SEARCH_FAIL,
|
2022-09-25 14:18:11 -07:00
|
|
|
EDIT_EVENT_NAME_CHANGE,
|
|
|
|
EDIT_EVENT_DESCRIPTION_CHANGE,
|
|
|
|
EDIT_EVENT_START_TIME_CHANGE,
|
|
|
|
EDIT_EVENT_END_TIME_CHANGE,
|
|
|
|
EDIT_EVENT_HAS_END_TIME_CHANGE,
|
|
|
|
EDIT_EVENT_APPROVAL_REQUIRED_CHANGE,
|
|
|
|
EDIT_EVENT_LOCATION_CHANGE,
|
2022-08-30 13:26:42 -07:00
|
|
|
EVENT_BANNER_UPLOAD_REQUEST,
|
|
|
|
EVENT_BANNER_UPLOAD_PROGRESS,
|
|
|
|
EVENT_BANNER_UPLOAD_SUCCESS,
|
|
|
|
EVENT_BANNER_UPLOAD_FAIL,
|
|
|
|
EVENT_BANNER_UPLOAD_UNDO,
|
|
|
|
EVENT_SUBMIT_REQUEST,
|
|
|
|
EVENT_SUBMIT_SUCCESS,
|
|
|
|
EVENT_SUBMIT_FAIL,
|
2022-09-07 11:03:26 -07:00
|
|
|
EVENT_JOIN_REQUEST,
|
|
|
|
EVENT_JOIN_SUCCESS,
|
|
|
|
EVENT_JOIN_FAIL,
|
|
|
|
EVENT_LEAVE_REQUEST,
|
|
|
|
EVENT_LEAVE_SUCCESS,
|
|
|
|
EVENT_LEAVE_FAIL,
|
2022-09-08 14:25:02 -07:00
|
|
|
EVENT_PARTICIPATIONS_FETCH_REQUEST,
|
|
|
|
EVENT_PARTICIPATIONS_FETCH_SUCCESS,
|
|
|
|
EVENT_PARTICIPATIONS_FETCH_FAIL,
|
|
|
|
EVENT_PARTICIPATIONS_EXPAND_REQUEST,
|
|
|
|
EVENT_PARTICIPATIONS_EXPAND_SUCCESS,
|
|
|
|
EVENT_PARTICIPATIONS_EXPAND_FAIL,
|
|
|
|
EVENT_PARTICIPATION_REQUESTS_FETCH_REQUEST,
|
|
|
|
EVENT_PARTICIPATION_REQUESTS_FETCH_SUCCESS,
|
|
|
|
EVENT_PARTICIPATION_REQUESTS_FETCH_FAIL,
|
|
|
|
EVENT_PARTICIPATION_REQUESTS_EXPAND_REQUEST,
|
|
|
|
EVENT_PARTICIPATION_REQUESTS_EXPAND_SUCCESS,
|
|
|
|
EVENT_PARTICIPATION_REQUESTS_EXPAND_FAIL,
|
2022-09-25 14:18:11 -07:00
|
|
|
EVENT_PARTICIPATION_REQUEST_AUTHORIZE_REQUEST,
|
|
|
|
EVENT_PARTICIPATION_REQUEST_AUTHORIZE_SUCCESS,
|
|
|
|
EVENT_PARTICIPATION_REQUEST_AUTHORIZE_FAIL,
|
|
|
|
EVENT_PARTICIPATION_REQUEST_REJECT_REQUEST,
|
|
|
|
EVENT_PARTICIPATION_REQUEST_REJECT_SUCCESS,
|
|
|
|
EVENT_PARTICIPATION_REQUEST_REJECT_FAIL,
|
|
|
|
EVENT_COMPOSE_CANCEL,
|
|
|
|
EVENT_FORM_SET,
|
2022-11-26 13:15:58 -08:00
|
|
|
RECENT_EVENTS_FETCH_REQUEST,
|
|
|
|
RECENT_EVENTS_FETCH_SUCCESS,
|
|
|
|
RECENT_EVENTS_FETCH_FAIL,
|
|
|
|
JOINED_EVENTS_FETCH_REQUEST,
|
|
|
|
JOINED_EVENTS_FETCH_SUCCESS,
|
|
|
|
JOINED_EVENTS_FETCH_FAIL,
|
2022-08-30 13:26:42 -07:00
|
|
|
locationSearch,
|
2022-09-25 14:18:11 -07:00
|
|
|
changeEditEventName,
|
|
|
|
changeEditEventDescription,
|
|
|
|
changeEditEventStartTime,
|
|
|
|
changeEditEventEndTime,
|
|
|
|
changeEditEventHasEndTime,
|
|
|
|
changeEditEventApprovalRequired,
|
|
|
|
changeEditEventLocation,
|
2022-08-30 13:26:42 -07:00
|
|
|
uploadEventBanner,
|
|
|
|
uploadEventBannerRequest,
|
|
|
|
uploadEventBannerProgress,
|
|
|
|
uploadEventBannerSuccess,
|
|
|
|
uploadEventBannerFail,
|
|
|
|
undoUploadEventBanner,
|
|
|
|
submitEvent,
|
|
|
|
submitEventRequest,
|
|
|
|
submitEventSuccess,
|
|
|
|
submitEventFail,
|
2022-09-07 11:03:26 -07:00
|
|
|
joinEvent,
|
|
|
|
joinEventRequest,
|
|
|
|
joinEventSuccess,
|
|
|
|
joinEventFail,
|
|
|
|
leaveEvent,
|
|
|
|
leaveEventRequest,
|
|
|
|
leaveEventSuccess,
|
|
|
|
leaveEventFail,
|
2022-09-08 14:25:02 -07:00
|
|
|
fetchEventParticipations,
|
|
|
|
fetchEventParticipationsRequest,
|
|
|
|
fetchEventParticipationsSuccess,
|
|
|
|
fetchEventParticipationsFail,
|
|
|
|
expandEventParticipations,
|
|
|
|
expandEventParticipationsRequest,
|
|
|
|
expandEventParticipationsSuccess,
|
|
|
|
expandEventParticipationsFail,
|
|
|
|
fetchEventParticipationRequests,
|
|
|
|
fetchEventParticipationRequestsRequest,
|
|
|
|
fetchEventParticipationRequestsSuccess,
|
|
|
|
fetchEventParticipationRequestsFail,
|
|
|
|
expandEventParticipationRequests,
|
|
|
|
expandEventParticipationRequestsRequest,
|
|
|
|
expandEventParticipationRequestsSuccess,
|
|
|
|
expandEventParticipationRequestsFail,
|
2022-09-25 14:18:11 -07:00
|
|
|
authorizeEventParticipationRequest,
|
|
|
|
authorizeEventParticipationRequestRequest,
|
|
|
|
authorizeEventParticipationRequestSuccess,
|
|
|
|
authorizeEventParticipationRequestFail,
|
|
|
|
rejectEventParticipationRequest,
|
|
|
|
rejectEventParticipationRequestRequest,
|
|
|
|
rejectEventParticipationRequestSuccess,
|
|
|
|
rejectEventParticipationRequestFail,
|
2022-09-08 14:25:02 -07:00
|
|
|
fetchEventIcs,
|
2022-09-25 14:18:11 -07:00
|
|
|
cancelEventCompose,
|
|
|
|
editEvent,
|
2022-11-26 13:15:58 -08:00
|
|
|
fetchRecentEvents,
|
|
|
|
fetchJoinedEvents,
|
2022-08-30 13:26:42 -07:00
|
|
|
};
|