mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-02 12:08:01 +00:00
- Adds pagination support for search. - Use composition API on all search related component. - Minor UI improvements. - Adds missing specs Loom video https://www.loom.com/share/5b01afa5c9204e7d97ff81b215621dde?sid=82ca6d22-ca8c-4d5e-8740-ba06ca4051ba
158 lines
4.4 KiB
JavaScript
158 lines
4.4 KiB
JavaScript
import SearchAPI from '../../api/search';
|
|
import types from '../mutation-types';
|
|
export const initialState = {
|
|
records: [],
|
|
contactRecords: [],
|
|
conversationRecords: [],
|
|
messageRecords: [],
|
|
uiFlags: {
|
|
isFetching: false,
|
|
isSearchCompleted: false,
|
|
contact: { isFetching: false },
|
|
conversation: { isFetching: false },
|
|
message: { isFetching: false },
|
|
},
|
|
};
|
|
|
|
export const getters = {
|
|
getConversations(state) {
|
|
return state.records;
|
|
},
|
|
getContactRecords(state) {
|
|
return state.contactRecords;
|
|
},
|
|
getConversationRecords(state) {
|
|
return state.conversationRecords;
|
|
},
|
|
getMessageRecords(state) {
|
|
return state.messageRecords;
|
|
},
|
|
getUIFlags(state) {
|
|
return state.uiFlags;
|
|
},
|
|
};
|
|
|
|
export const actions = {
|
|
async get({ commit }, { q }) {
|
|
commit(types.SEARCH_CONVERSATIONS_SET, []);
|
|
if (!q) {
|
|
return;
|
|
}
|
|
commit(types.SEARCH_CONVERSATIONS_SET_UI_FLAG, { isFetching: true });
|
|
try {
|
|
const {
|
|
data: { payload },
|
|
} = await SearchAPI.get({ q });
|
|
commit(types.SEARCH_CONVERSATIONS_SET, payload);
|
|
} catch (error) {
|
|
// Ignore error
|
|
} finally {
|
|
commit(types.SEARCH_CONVERSATIONS_SET_UI_FLAG, {
|
|
isFetching: false,
|
|
});
|
|
}
|
|
},
|
|
async fullSearch({ commit, dispatch }, { q }) {
|
|
if (!q) {
|
|
return;
|
|
}
|
|
commit(types.FULL_SEARCH_SET_UI_FLAG, {
|
|
isFetching: true,
|
|
isSearchCompleted: false,
|
|
});
|
|
try {
|
|
await Promise.all([
|
|
dispatch('contactSearch', { q }),
|
|
dispatch('conversationSearch', { q }),
|
|
dispatch('messageSearch', { q }),
|
|
]);
|
|
} catch (error) {
|
|
// Ignore error
|
|
} finally {
|
|
commit(types.FULL_SEARCH_SET_UI_FLAG, {
|
|
isFetching: false,
|
|
isSearchCompleted: true,
|
|
});
|
|
}
|
|
},
|
|
async contactSearch({ commit }, { q, page = 1 }) {
|
|
commit(types.CONTACT_SEARCH_SET_UI_FLAG, { isFetching: true });
|
|
try {
|
|
const { data } = await SearchAPI.contacts({ q, page });
|
|
commit(types.CONTACT_SEARCH_SET, data.payload.contacts);
|
|
} catch (error) {
|
|
// Ignore error
|
|
} finally {
|
|
commit(types.CONTACT_SEARCH_SET_UI_FLAG, { isFetching: false });
|
|
}
|
|
},
|
|
async conversationSearch({ commit }, { q, page = 1 }) {
|
|
commit(types.CONVERSATION_SEARCH_SET_UI_FLAG, { isFetching: true });
|
|
try {
|
|
const { data } = await SearchAPI.conversations({ q, page });
|
|
commit(types.CONVERSATION_SEARCH_SET, data.payload.conversations);
|
|
} catch (error) {
|
|
// Ignore error
|
|
} finally {
|
|
commit(types.CONVERSATION_SEARCH_SET_UI_FLAG, { isFetching: false });
|
|
}
|
|
},
|
|
async messageSearch({ commit }, { q, page = 1 }) {
|
|
commit(types.MESSAGE_SEARCH_SET_UI_FLAG, { isFetching: true });
|
|
try {
|
|
const { data } = await SearchAPI.messages({ q, page });
|
|
commit(types.MESSAGE_SEARCH_SET, data.payload.messages);
|
|
} catch (error) {
|
|
// Ignore error
|
|
} finally {
|
|
commit(types.MESSAGE_SEARCH_SET_UI_FLAG, { isFetching: false });
|
|
}
|
|
},
|
|
async clearSearchResults({ commit }) {
|
|
commit(types.CLEAR_SEARCH_RESULTS);
|
|
},
|
|
};
|
|
|
|
export const mutations = {
|
|
[types.SEARCH_CONVERSATIONS_SET](state, records) {
|
|
state.records = records;
|
|
},
|
|
[types.CONTACT_SEARCH_SET](state, records) {
|
|
state.contactRecords = [...state.contactRecords, ...records];
|
|
},
|
|
[types.CONVERSATION_SEARCH_SET](state, records) {
|
|
state.conversationRecords = [...state.conversationRecords, ...records];
|
|
},
|
|
[types.MESSAGE_SEARCH_SET](state, records) {
|
|
state.messageRecords = [...state.messageRecords, ...records];
|
|
},
|
|
[types.SEARCH_CONVERSATIONS_SET_UI_FLAG](state, uiFlags) {
|
|
state.uiFlags = { ...state.uiFlags, ...uiFlags };
|
|
},
|
|
[types.FULL_SEARCH_SET_UI_FLAG](state, uiFlags) {
|
|
state.uiFlags = { ...state.uiFlags, ...uiFlags };
|
|
},
|
|
[types.CONTACT_SEARCH_SET_UI_FLAG](state, uiFlags) {
|
|
state.uiFlags.contact = { ...state.uiFlags.contact, ...uiFlags };
|
|
},
|
|
[types.CONVERSATION_SEARCH_SET_UI_FLAG](state, uiFlags) {
|
|
state.uiFlags.conversation = { ...state.uiFlags.conversation, ...uiFlags };
|
|
},
|
|
[types.MESSAGE_SEARCH_SET_UI_FLAG](state, uiFlags) {
|
|
state.uiFlags.message = { ...state.uiFlags.message, ...uiFlags };
|
|
},
|
|
[types.CLEAR_SEARCH_RESULTS](state) {
|
|
state.contactRecords = [];
|
|
state.conversationRecords = [];
|
|
state.messageRecords = [];
|
|
},
|
|
};
|
|
|
|
export default {
|
|
namespaced: true,
|
|
state: initialState,
|
|
getters,
|
|
actions,
|
|
mutations,
|
|
};
|