forked from Ivasoft/mattermost-mobile
75 lines
2.0 KiB
TypeScript
75 lines
2.0 KiB
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
import React from 'react';
|
|
import {View, Platform} from 'react-native';
|
|
|
|
import {removeDraftFile} from '@actions/local/draft';
|
|
import CompassIcon from '@components/compass_icon';
|
|
import TouchableWithFeedback from '@components/touchable_with_feedback';
|
|
import {useServerUrl} from '@context/server';
|
|
import {useTheme} from '@context/theme';
|
|
import DraftUploadManager from '@managers/draft_upload_manager';
|
|
import {makeStyleSheetFromTheme, changeOpacity} from '@utils/theme';
|
|
|
|
type Props = {
|
|
channelId: string;
|
|
rootId: string;
|
|
clientId: string;
|
|
}
|
|
|
|
const getStyleSheet = makeStyleSheetFromTheme((theme) => {
|
|
return {
|
|
tappableContainer: {
|
|
position: 'absolute',
|
|
elevation: 11,
|
|
top: -7,
|
|
right: -8,
|
|
width: 24,
|
|
height: 24,
|
|
},
|
|
removeButton: {
|
|
borderRadius: 12,
|
|
alignSelf: 'center',
|
|
marginTop: Platform.select({
|
|
ios: 5.4,
|
|
android: 4.75,
|
|
}),
|
|
backgroundColor: theme.centerChannelBg,
|
|
width: 24,
|
|
height: 25,
|
|
},
|
|
};
|
|
});
|
|
|
|
export default function UploadRemove({
|
|
channelId,
|
|
rootId,
|
|
clientId,
|
|
}: Props) {
|
|
const theme = useTheme();
|
|
const style = getStyleSheet(theme);
|
|
const serverUrl = useServerUrl();
|
|
|
|
const onPress = () => {
|
|
DraftUploadManager.cancel(clientId);
|
|
removeDraftFile(serverUrl, channelId, rootId, clientId);
|
|
};
|
|
|
|
return (
|
|
<TouchableWithFeedback
|
|
style={style.tappableContainer}
|
|
onPress={onPress}
|
|
type={'opacity'}
|
|
>
|
|
<View style={style.removeButton}>
|
|
<CompassIcon
|
|
name='close-circle'
|
|
color={changeOpacity(theme.centerChannelColor, 0.64)}
|
|
size={24}
|
|
/>
|
|
</View>
|
|
</TouchableWithFeedback>
|
|
);
|
|
}
|