2020-08-23 19:12:48 -07:00
|
|
|
import api from '../api';
|
2021-10-05 10:59:37 -07:00
|
|
|
import { getFeatures } from 'soapbox/utils/features';
|
2020-08-23 19:12:48 -07:00
|
|
|
|
|
|
|
const noOp = () => {};
|
|
|
|
|
2021-10-19 09:25:43 -07:00
|
|
|
export function fetchMedia(mediaId) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
return api(getState).get(`/api/v1/media/${mediaId}`);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export function updateMedia(mediaId, params) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
return api(getState).put(`/api/v1/media/${mediaId}`, params);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2021-10-05 10:59:37 -07:00
|
|
|
export function uploadMediaV1(data, onUploadProgress = noOp) {
|
|
|
|
return (dispatch, getState) => {
|
2020-08-23 19:12:48 -07:00
|
|
|
return api(getState).post('/api/v1/media', data, {
|
|
|
|
onUploadProgress: onUploadProgress,
|
|
|
|
});
|
|
|
|
};
|
|
|
|
}
|
2021-10-05 10:59:37 -07:00
|
|
|
|
|
|
|
export function uploadMediaV2(data, onUploadProgress = noOp) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
return api(getState).post('/api/v2/media', data, {
|
|
|
|
onUploadProgress: onUploadProgress,
|
|
|
|
});
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export function uploadMedia(data, onUploadProgress = noOp) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
const state = getState();
|
|
|
|
const instance = state.get('instance');
|
|
|
|
const features = getFeatures(instance);
|
|
|
|
|
|
|
|
if (features.mediaV2) {
|
|
|
|
return dispatch(uploadMediaV2(data, onUploadProgress));
|
|
|
|
} else {
|
|
|
|
return dispatch(uploadMediaV1(data, onUploadProgress));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|