mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-01 11:37:58 +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,
|
|
};
|