forked from Ivasoft/mattermost-mobile
* Add set status feature Small code refactoring Add Do Not Disturb option * Add Account Settings screen Add username, nicname, and position fields Add email field get deviceHeight from redux Clean up onPress handler in Settings Refactor each account settings item to it's own component Clean up email field and updateUser action method Use mobile localization format in en.json Update profile image Clean up ProfilePicture for editing Add loading and error components in AccountSettings Refactor updateRequest state into a function Follow design specs Remove unnecessary this.state.emailUpdated Polish AccountSettings and secondary components Refactor AttachmentButton into it's own componentg Add Account Settings icon in General Settings Add TODO comments * Update user status * Edit Profile screen refactored * Fix edit profile item text color
118 lines
3.2 KiB
JavaScript
118 lines
3.2 KiB
JavaScript
// Copyright (c) 2017-present Mattermost, Inc. All Rights Reserved.
|
|
// See License.txt for license information.
|
|
|
|
import FormData from 'form-data';
|
|
import {Platform} from 'react-native';
|
|
import {uploadFile} from 'mattermost-redux/actions/files';
|
|
import {parseClientIdsFromFormData} from 'mattermost-redux/utils/file_utils';
|
|
|
|
import {buildFileUploadData, generateId} from 'app/utils/file';
|
|
import {ViewTypes} from 'app/constants';
|
|
|
|
export function handleUploadFiles(files, rootId) {
|
|
return async (dispatch, getState) => {
|
|
const state = getState();
|
|
|
|
const channelId = state.entities.channels.currentChannelId;
|
|
const formData = new FormData();
|
|
const clientIds = [];
|
|
|
|
files.forEach((file) => {
|
|
const fileData = buildFileUploadData(file);
|
|
const clientId = generateId();
|
|
|
|
clientIds.push({
|
|
clientId,
|
|
localPath: fileData.uri,
|
|
name: fileData.name,
|
|
type: fileData.mimeType,
|
|
extension: fileData.extension
|
|
});
|
|
|
|
formData.append('files', fileData);
|
|
formData.append('channel_id', channelId);
|
|
formData.append('client_ids', clientId);
|
|
});
|
|
|
|
let formBoundary;
|
|
if (Platform.os === 'ios') {
|
|
formBoundary = '--mobile.client.file.upload';
|
|
}
|
|
|
|
dispatch({
|
|
type: ViewTypes.SET_TEMP_UPLOAD_FILES_FOR_POST_DRAFT,
|
|
clientIds,
|
|
channelId,
|
|
rootId
|
|
});
|
|
|
|
await uploadFile(channelId, rootId, parseClientIdsFromFormData(formData), formData, formBoundary)(dispatch, getState);
|
|
};
|
|
}
|
|
|
|
export function retryFileUpload(file, rootId) {
|
|
return async (dispatch, getState) => {
|
|
const state = getState();
|
|
|
|
const channelId = state.entities.channels.currentChannelId;
|
|
const formData = new FormData();
|
|
|
|
const fileData = {
|
|
uri: file.localPath,
|
|
name: file.name,
|
|
type: file.type
|
|
};
|
|
|
|
formData.append('files', fileData);
|
|
formData.append('channel_id', channelId);
|
|
formData.append('client_ids', file.clientId);
|
|
|
|
let formBoundary;
|
|
if (Platform.os === 'ios') {
|
|
formBoundary = '--mobile.client.file.upload';
|
|
}
|
|
|
|
dispatch({
|
|
type: ViewTypes.RETRY_UPLOAD_FILE_FOR_POST,
|
|
clientId: file.clientId,
|
|
channelId,
|
|
rootId
|
|
});
|
|
|
|
await uploadFile(channelId, rootId, [file.clientId], formData, formBoundary)(dispatch, getState);
|
|
};
|
|
}
|
|
|
|
export function handleClearFiles(channelId, rootId) {
|
|
return {
|
|
type: ViewTypes.CLEAR_FILES_FOR_POST_DRAFT,
|
|
channelId,
|
|
rootId
|
|
};
|
|
}
|
|
|
|
export function handleClearFailedFiles(channelId, rootId) {
|
|
return {
|
|
type: ViewTypes.CLEAR_FAILED_FILES_FOR_POST_DRAFT,
|
|
channelId,
|
|
rootId
|
|
};
|
|
}
|
|
|
|
export function handleRemoveFile(clientId, channelId, rootId) {
|
|
return {
|
|
type: ViewTypes.REMOVE_FILE_FROM_POST_DRAFT,
|
|
clientId,
|
|
channelId,
|
|
rootId
|
|
};
|
|
}
|
|
|
|
export function handleRemoveLastFile(channelId, rootId) {
|
|
return {
|
|
type: ViewTypes.REMOVE_LAST_FILE_FROM_POST_DRAFT,
|
|
channelId,
|
|
rootId
|
|
};
|
|
}
|