mirror of
				https://github.com/lingble/chatwoot.git
				synced 2025-11-04 04:57:51 +00:00 
			
		
		
		
	This change allows the administrator user to delete a contact and its related data like conversations, contact inboxes, and reports. Fixes #1929
		
			
				
	
	
		
			141 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			141 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
import AuthAPI from '../api/auth';
 | 
						|
import BaseActionCableConnector from '../../shared/helpers/BaseActionCableConnector';
 | 
						|
import { newMessageNotification } from 'shared/helpers/AudioNotificationHelper';
 | 
						|
 | 
						|
class ActionCableConnector extends BaseActionCableConnector {
 | 
						|
  constructor(app, pubsubToken) {
 | 
						|
    const { websocketURL = '' } = window.chatwootConfig || {};
 | 
						|
    super(app, pubsubToken, websocketURL);
 | 
						|
    this.CancelTyping = [];
 | 
						|
    this.events = {
 | 
						|
      'message.created': this.onMessageCreated,
 | 
						|
      'message.updated': this.onMessageUpdated,
 | 
						|
      'conversation.created': this.onConversationCreated,
 | 
						|
      'conversation.status_changed': this.onStatusChange,
 | 
						|
      'user:logout': this.onLogout,
 | 
						|
      'page:reload': this.onReload,
 | 
						|
      'assignee.changed': this.onAssigneeChanged,
 | 
						|
      'conversation.typing_on': this.onTypingOn,
 | 
						|
      'conversation.typing_off': this.onTypingOff,
 | 
						|
      'conversation.contact_changed': this.onConversationContactChange,
 | 
						|
      'presence.update': this.onPresenceUpdate,
 | 
						|
      'contact.deleted': this.onContactDelete,
 | 
						|
    };
 | 
						|
  }
 | 
						|
 | 
						|
  isAValidEvent = data => {
 | 
						|
    return this.app.$store.getters.getCurrentAccountId === data.account_id;
 | 
						|
  };
 | 
						|
 | 
						|
  onMessageUpdated = data => {
 | 
						|
    this.app.$store.dispatch('updateMessage', data);
 | 
						|
  };
 | 
						|
 | 
						|
  onPresenceUpdate = data => {
 | 
						|
    this.app.$store.dispatch('contacts/updatePresence', data.contacts);
 | 
						|
    this.app.$store.dispatch('agents/updatePresence', data.users);
 | 
						|
    this.app.$store.dispatch('setCurrentUserAvailabilityStatus', data.users);
 | 
						|
  };
 | 
						|
 | 
						|
  onConversationContactChange = payload => {
 | 
						|
    const { meta = {}, id: conversationId } = payload;
 | 
						|
    const { sender } = meta || {};
 | 
						|
    if (conversationId) {
 | 
						|
      this.app.$store.dispatch('updateConversationContact', {
 | 
						|
        conversationId,
 | 
						|
        ...sender,
 | 
						|
      });
 | 
						|
    }
 | 
						|
  };
 | 
						|
 | 
						|
  onAssigneeChanged = payload => {
 | 
						|
    const { id } = payload;
 | 
						|
    if (id) {
 | 
						|
      this.app.$store.dispatch('updateConversation', payload);
 | 
						|
    }
 | 
						|
    this.fetchConversationStats();
 | 
						|
  };
 | 
						|
 | 
						|
  onConversationCreated = data => {
 | 
						|
    this.app.$store.dispatch('addConversation', data);
 | 
						|
    this.fetchConversationStats();
 | 
						|
  };
 | 
						|
 | 
						|
  onLogout = () => AuthAPI.logout();
 | 
						|
 | 
						|
  onMessageCreated = data => {
 | 
						|
    newMessageNotification(data);
 | 
						|
    this.app.$store.dispatch('addMessage', data);
 | 
						|
  };
 | 
						|
 | 
						|
  onReload = () => window.location.reload();
 | 
						|
 | 
						|
  onStatusChange = data => {
 | 
						|
    this.app.$store.dispatch('updateConversation', data);
 | 
						|
    this.fetchConversationStats();
 | 
						|
  };
 | 
						|
 | 
						|
  onTypingOn = ({ conversation, user }) => {
 | 
						|
    const conversationId = conversation.id;
 | 
						|
 | 
						|
    this.clearTimer(conversationId);
 | 
						|
    this.app.$store.dispatch('conversationTypingStatus/create', {
 | 
						|
      conversationId,
 | 
						|
      user,
 | 
						|
    });
 | 
						|
    this.initTimer({ conversation, user });
 | 
						|
  };
 | 
						|
 | 
						|
  onTypingOff = ({ conversation, user }) => {
 | 
						|
    const conversationId = conversation.id;
 | 
						|
 | 
						|
    this.clearTimer(conversationId);
 | 
						|
    this.app.$store.dispatch('conversationTypingStatus/destroy', {
 | 
						|
      conversationId,
 | 
						|
      user,
 | 
						|
    });
 | 
						|
  };
 | 
						|
 | 
						|
  clearTimer = conversationId => {
 | 
						|
    const timerEvent = this.CancelTyping[conversationId];
 | 
						|
 | 
						|
    if (timerEvent) {
 | 
						|
      clearTimeout(timerEvent);
 | 
						|
      this.CancelTyping[conversationId] = null;
 | 
						|
    }
 | 
						|
  };
 | 
						|
 | 
						|
  initTimer = ({ conversation, user }) => {
 | 
						|
    const conversationId = conversation.id;
 | 
						|
    // Turn off typing automatically after 30 seconds
 | 
						|
    this.CancelTyping[conversationId] = setTimeout(() => {
 | 
						|
      this.onTypingOff({ conversation, user });
 | 
						|
    }, 30000);
 | 
						|
  };
 | 
						|
 | 
						|
  fetchConversationStats = () => {
 | 
						|
    bus.$emit('fetch_conversation_stats');
 | 
						|
  };
 | 
						|
 | 
						|
  onContactDelete = data => {
 | 
						|
    this.app.$store.dispatch(
 | 
						|
      'contacts/deleteContactThroughConversations',
 | 
						|
      data.id
 | 
						|
    );
 | 
						|
    this.fetchConversationStats();
 | 
						|
  };
 | 
						|
}
 | 
						|
 | 
						|
export default {
 | 
						|
  init() {
 | 
						|
    if (AuthAPI.isLoggedIn()) {
 | 
						|
      const actionCable = new ActionCableConnector(
 | 
						|
        window.WOOT,
 | 
						|
        AuthAPI.getPubSubToken()
 | 
						|
      );
 | 
						|
      return actionCable;
 | 
						|
    }
 | 
						|
    return null;
 | 
						|
  },
 | 
						|
};
 |