mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-24 23:15:11 +00:00
Fixes https://github.com/chatwoot/chatwoot/issues/8436 Fixes https://github.com/chatwoot/chatwoot/issues/9767 Fixes https://github.com/chatwoot/chatwoot/issues/10156 Fixes https://github.com/chatwoot/chatwoot/issues/6031 Fixes https://github.com/chatwoot/chatwoot/issues/5696 Fixes https://github.com/chatwoot/chatwoot/issues/9250 Fixes https://github.com/chatwoot/chatwoot/issues/9762 --------- Co-authored-by: Pranav <pranavrajs@gmail.com> Co-authored-by: Sivin Varghese <64252451+iamsivin@users.noreply.github.com>
117 lines
3.3 KiB
JavaScript
117 lines
3.3 KiB
JavaScript
import { MESSAGE_TYPE } from 'widget/helpers/constants';
|
|
import { findUndeliveredMessage } from './helpers';
|
|
|
|
export const mutations = {
|
|
clearConversations($state) {
|
|
$state.conversations = {};
|
|
},
|
|
pushMessageToConversation($state, message) {
|
|
const { id, status, message_type: type } = message;
|
|
|
|
const messagesInbox = $state.conversations;
|
|
const isMessageIncoming = type === MESSAGE_TYPE.INCOMING;
|
|
const isTemporaryMessage = status === 'in_progress';
|
|
|
|
if (!isMessageIncoming || isTemporaryMessage) {
|
|
messagesInbox[id] = message;
|
|
return;
|
|
}
|
|
|
|
const [messageInConversation] = findUndeliveredMessage(
|
|
messagesInbox,
|
|
message
|
|
);
|
|
if (!messageInConversation) {
|
|
messagesInbox[id] = message;
|
|
} else {
|
|
// [VITE] instead of leaving undefined behind, we remove it completely
|
|
// remove the temporary message and replace it with the new message
|
|
// messagesInbox[messageInConversation.id] = undefined;
|
|
delete messagesInbox[messageInConversation.id];
|
|
messagesInbox[id] = message;
|
|
}
|
|
},
|
|
|
|
updateAttachmentMessageStatus($state, { message, tempId }) {
|
|
const { id } = message;
|
|
const messagesInbox = $state.conversations;
|
|
|
|
const messageInConversation = messagesInbox[tempId];
|
|
|
|
if (messageInConversation) {
|
|
// [VITE] instead of leaving undefined behind, we remove it completely
|
|
// remove the temporary message and replace it with the new message
|
|
// messagesInbox[tempId] = undefined;
|
|
delete messagesInbox[tempId];
|
|
messagesInbox[id] = { ...message };
|
|
}
|
|
},
|
|
|
|
setConversationUIFlag($state, uiFlags) {
|
|
$state.uiFlags = {
|
|
...$state.uiFlags,
|
|
...uiFlags,
|
|
};
|
|
},
|
|
|
|
setConversationListLoading($state, status) {
|
|
$state.uiFlags.isFetchingList = status;
|
|
},
|
|
|
|
setMessagesInConversation($state, payload) {
|
|
if (!payload.length) {
|
|
$state.uiFlags.allMessagesLoaded = true;
|
|
return;
|
|
}
|
|
|
|
payload.forEach(message => {
|
|
$state.conversations[message.id] = message;
|
|
});
|
|
},
|
|
|
|
setMissingMessagesInConversation($state, payload) {
|
|
$state.conversation = payload;
|
|
},
|
|
|
|
updateMessage($state, { id, content_attributes }) {
|
|
$state.conversations[id] = {
|
|
...$state.conversations[id],
|
|
content_attributes: {
|
|
...($state.conversations[id].content_attributes || {}),
|
|
...content_attributes,
|
|
},
|
|
};
|
|
},
|
|
|
|
updateMessageMeta($state, { id, meta }) {
|
|
const message = $state.conversations[id];
|
|
if (!message) return;
|
|
|
|
const newMeta = message.meta ? { ...message.meta, ...meta } : { ...meta };
|
|
message.meta = { ...newMeta };
|
|
},
|
|
|
|
deleteMessage($state, id) {
|
|
delete $state.conversations[id];
|
|
// [VITE] In Vue 3 proxy objects, we can't delete properties by setting them to undefined
|
|
// Instead, we have to use the delete operator
|
|
// $state.conversations[id] = undefined;
|
|
},
|
|
|
|
toggleAgentTypingStatus($state, { status }) {
|
|
$state.uiFlags.isAgentTyping = status === 'on';
|
|
},
|
|
|
|
setMetaUserLastSeenAt($state, lastSeen) {
|
|
$state.meta.userLastSeenAt = lastSeen;
|
|
},
|
|
|
|
setLastMessageId($state) {
|
|
const { conversations } = $state;
|
|
const lastMessage = Object.values(conversations).pop();
|
|
if (!lastMessage) return;
|
|
const { id } = lastMessage;
|
|
$state.lastMessageId = id;
|
|
},
|
|
};
|