mirror of
				https://github.com/lingble/chatwoot.git
				synced 2025-11-03 20:48:07 +00:00 
			
		
		
		
	This is the continuation of the design update series. Canned responses listing page is rewritten with the design change. --------- Co-authored-by: Sivin Varghese <64252451+iamsivin@users.noreply.github.com> Co-authored-by: iamsivin <iamsivin@gmail.com> Co-authored-by: Shivam Mishra <scm.mymail@gmail.com> Co-authored-by: Vishnu Narayanan <iamwishnu@gmail.com>
		
			
				
	
	
		
			116 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
import { throwErrorMessage } from 'dashboard/store/utils/api';
 | 
						|
import * as MutationHelpers from 'shared/helpers/vuex/mutationHelpers';
 | 
						|
import * as types from '../mutation-types';
 | 
						|
import CannedResponseAPI from '../../api/cannedResponse';
 | 
						|
 | 
						|
const state = {
 | 
						|
  records: [],
 | 
						|
  uiFlags: {
 | 
						|
    fetchingList: false,
 | 
						|
    fetchingItem: false,
 | 
						|
    creatingItem: false,
 | 
						|
    updatingItem: false,
 | 
						|
    deletingItem: false,
 | 
						|
  },
 | 
						|
};
 | 
						|
 | 
						|
const getters = {
 | 
						|
  getCannedResponses(_state) {
 | 
						|
    return _state.records;
 | 
						|
  },
 | 
						|
  getSortedCannedResponses(_state) {
 | 
						|
    return sortOrder =>
 | 
						|
      [..._state.records].sort((a, b) => {
 | 
						|
        if (sortOrder === 'asc') {
 | 
						|
          return a.short_code.localeCompare(b.short_code);
 | 
						|
        }
 | 
						|
        return b.short_code.localeCompare(a.short_code);
 | 
						|
      });
 | 
						|
  },
 | 
						|
  getUIFlags(_state) {
 | 
						|
    return _state.uiFlags;
 | 
						|
  },
 | 
						|
};
 | 
						|
 | 
						|
const actions = {
 | 
						|
  getCannedResponse: async function getCannedResponse(
 | 
						|
    { commit },
 | 
						|
    { searchKey } = {}
 | 
						|
  ) {
 | 
						|
    commit(types.default.SET_CANNED_UI_FLAG, { fetchingList: true });
 | 
						|
    try {
 | 
						|
      const response = await CannedResponseAPI.get({ searchKey });
 | 
						|
      commit(types.default.SET_CANNED, response.data);
 | 
						|
      commit(types.default.SET_CANNED_UI_FLAG, { fetchingList: false });
 | 
						|
    } catch (error) {
 | 
						|
      commit(types.default.SET_CANNED_UI_FLAG, { fetchingList: false });
 | 
						|
    }
 | 
						|
  },
 | 
						|
 | 
						|
  createCannedResponse: async function createCannedResponse(
 | 
						|
    { commit },
 | 
						|
    cannedObj
 | 
						|
  ) {
 | 
						|
    commit(types.default.SET_CANNED_UI_FLAG, { creatingItem: true });
 | 
						|
    try {
 | 
						|
      const response = await CannedResponseAPI.create(cannedObj);
 | 
						|
      commit(types.default.ADD_CANNED, response.data);
 | 
						|
      commit(types.default.SET_CANNED_UI_FLAG, { creatingItem: false });
 | 
						|
      return response.data;
 | 
						|
    } catch (error) {
 | 
						|
      commit(types.default.SET_CANNED_UI_FLAG, { creatingItem: false });
 | 
						|
      return throwErrorMessage(error);
 | 
						|
    }
 | 
						|
  },
 | 
						|
 | 
						|
  updateCannedResponse: async function updateCannedResponse(
 | 
						|
    { commit },
 | 
						|
    { id, ...updateObj }
 | 
						|
  ) {
 | 
						|
    commit(types.default.SET_CANNED_UI_FLAG, { updatingItem: true });
 | 
						|
    try {
 | 
						|
      const response = await CannedResponseAPI.update(id, updateObj);
 | 
						|
      commit(types.default.EDIT_CANNED, response.data);
 | 
						|
      commit(types.default.SET_CANNED_UI_FLAG, { updatingItem: false });
 | 
						|
      return response.data;
 | 
						|
    } catch (error) {
 | 
						|
      commit(types.default.SET_CANNED_UI_FLAG, { updatingItem: false });
 | 
						|
      return throwErrorMessage(error);
 | 
						|
    }
 | 
						|
  },
 | 
						|
 | 
						|
  deleteCannedResponse: async function deleteCannedResponse({ commit }, id) {
 | 
						|
    commit(types.default.SET_CANNED_UI_FLAG, { deletingItem: true });
 | 
						|
    try {
 | 
						|
      await CannedResponseAPI.delete(id);
 | 
						|
      commit(types.default.DELETE_CANNED, id);
 | 
						|
      commit(types.default.SET_CANNED_UI_FLAG, { deletingItem: true });
 | 
						|
      return id;
 | 
						|
    } catch (error) {
 | 
						|
      commit(types.default.SET_CANNED_UI_FLAG, { deletingItem: true });
 | 
						|
      return throwErrorMessage(error);
 | 
						|
    }
 | 
						|
  },
 | 
						|
};
 | 
						|
 | 
						|
const mutations = {
 | 
						|
  [types.default.SET_CANNED_UI_FLAG](_state, data) {
 | 
						|
    _state.uiFlags = {
 | 
						|
      ..._state.uiFlags,
 | 
						|
      ...data,
 | 
						|
    };
 | 
						|
  },
 | 
						|
 | 
						|
  [types.default.SET_CANNED]: MutationHelpers.set,
 | 
						|
  [types.default.ADD_CANNED]: MutationHelpers.create,
 | 
						|
  [types.default.EDIT_CANNED]: MutationHelpers.update,
 | 
						|
  [types.default.DELETE_CANNED]: MutationHelpers.destroy,
 | 
						|
};
 | 
						|
 | 
						|
export default {
 | 
						|
  state,
 | 
						|
  getters,
 | 
						|
  actions,
 | 
						|
  mutations,
 | 
						|
};
 |