Rocket.Chat.ReactNative/app/containers/MessageErrorActions.tsx

100 lines
2.4 KiB
TypeScript

import { forwardRef, useImperativeHandle } from 'react';
import RocketChat from '../lib/rocketchat';
import database from '../lib/database';
import protectedFunction from '../lib/methods/helpers/protectedFunction';
import { useActionSheet } from './ActionSheet';
import I18n from '../i18n';
import log from '../utils/log';
const MessageErrorActions = forwardRef(({ tmid }: any, ref): any => {
const { showActionSheet }: any = useActionSheet();
const handleResend = protectedFunction(async (message: any) => {
await RocketChat.resendMessage(message, tmid);
});
const handleDelete = async (message: any) => {
try {
const db = database.active;
const deleteBatch: any = [];
const msgCollection = db.get('messages');
const threadCollection = db.get('threads');
// Delete the object (it can be Message or ThreadMessage instance)
deleteBatch.push(message.prepareDestroyPermanently());
// If it's a thread, we find and delete the whole tree, if necessary
if (tmid) {
try {
const msg = await msgCollection.find(message.id);
deleteBatch.push(msg.prepareDestroyPermanently());
} catch {
// Do nothing: message not found
}
try {
// Find the thread header and update it
const msg = await msgCollection.find(tmid);
if (msg.tcount <= 1) {
deleteBatch.push(
msg.prepareUpdate((m: any) => {
m.tcount = null;
m.tlm = null;
})
);
try {
// If the whole thread was removed, delete the thread
const thread = await threadCollection.find(tmid);
deleteBatch.push(thread.prepareDestroyPermanently());
} catch {
// Do nothing: thread not found
}
} else {
deleteBatch.push(
msg.prepareUpdate((m: any) => {
m.tcount -= 1;
})
);
}
} catch {
// Do nothing: message not found
}
}
await db.action(async () => {
await db.batch(...deleteBatch);
});
} catch (e) {
log(e);
}
};
const showMessageErrorActions = (message: any) => {
showActionSheet({
options: [
{
title: I18n.t('Resend'),
icon: 'send',
onPress: () => handleResend(message)
},
{
title: I18n.t('Delete'),
icon: 'delete',
danger: true,
onPress: () => handleDelete(message)
}
],
hasCancel: true
});
};
useImperativeHandle(ref, () => ({
showMessageErrorActions
}));
return null;
});
export default MessageErrorActions;